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INTRODUCTORY NOTE 



This Self-Instructional Text Book is designed to perform 
the function of teaching you to program for the IBM 7090 
computer. 

There will be no formal test at any time throughout the 
course. You will go through it as fast or as slowly as you 
desire. It is recommended that study periods should not 
extend beyond two hours and that no more than two such 
(two hour) periods be utilized during any one day. 

There are large numbers of problems and exercises scat- 
tered throughout the book. In every case, the correct 
answer is given on the back of the page. You are to work 
each problem in the space allotted to it in the book and 
then check your answer with the correct answer given. If 
your answer was incorrect, go back to the previous page for 
an additional review. 

There is nothing to keep you from cheating by looking 
at the correct answer before you have attempted to work 
the problem except the realization that you will not learn 
to prograjn if you do so. The fact that you have this book 
in front of you indicates that you want to learn to pro- 
gram. If this is true, then please follow all instructions 
to the letter. Thank you for your cooperation. 

Computer manufacturers are constantly making advances 
and some of the limitations listed in this text will be 
exceeded, but as long as the 7090 or similar computers are 
used, the general information and programming methodology 
will be applicable. 
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GENERAL INFORMATION 

Before getting into the mechanics of programming for 
the 7090, a certain amount of general information relating 
to the characteristics and operation of the machine, should 
be discussed. 

The 7090 is a scientific computer. Although it 
can, and does, do other work, its major function is that of 
solving complex mathematical problems. Despite complex 
formulas, every problem can be broken dovm to the four 
basic arithmetic operations of addition, subtraction, multi- 
plication and division. This is the method the computer 
uses in solving its problems. It may have to multiply a set 
of numbers a thousand times (or a million times), but this 
poses no problem as each operation is executed in a tiny 
fraction of a second. The computer is controlled and told 
what to do by human beings through the use of programs , 
which are interpreted emd executed by the machine. 

A program , is a sequence of instructions, stored 
internally in the machine, which tell the computer exactly 
what to do with the data to be processed. It must take 
into account every eventuality and all possibilities. 
Nothing must be left to chance because the machine has no 
capacity for thinking. It can only do what it has been 
told to do by the program . For example, if an overflow 
occurs during an arithmetic operation eind the programmer 
has not provided for this possibility in his program, the 
machine will not be able to handle it. 

There are three phases in computer processing: 
INPUT, COMPUTATION and OUTPUT. The input phase consists of 
placing the instructions and data to be processed into the 
computer. Input may be punched cards or magnetic tape al- 
though magnetic tape is more commonly used as it is a much 
faster method. 

The computation phase carries out the instructions. 
It has two functions, that of arithmetic and control . 
Arithmetic simply carries out those instructions that are 
concerned with arithmetic operations and control carries 
out the instructions in a specified order. Normally, the 
computer carries out instructions sequentially (one after 
the other) , but the programmer may use certain control 
instructions which may instruct the computer to proceed to 
any instruction in the program. 
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The output phase consists of reporting the results 
of the computer action. This may be in printed form, on 
punched cards or on tape. It is most economical to pro- 
duce the output on tape, then if one of the other products 
is desired, it may be accomplished off-line (detached from 
the computer), saving considerable machine operating time. 

Tape, card and printer units are connected to the 
DATA CHANNEL (DC) , which is connected to the Central Pro- 
cessing Unit of the computer. The DC allows input and 
output of information at the same time that computation is 
taking place. Channels A through H are available. 

Each Channel may have up to ten tape units, A 
printer, card reader and pxinch may be attached to each 
Channel, All Channels may operate at the same time, but 
only one input/output unit per Channel may be in operation 
at any one time. 

The printer writes at the rate of I50 lines per 
minute. The card reader reads cards at the rate of 250 
cards per minute . The P%inch can punch cards at the rate of 
100 cards per minute. These are all extremely high speeds, 
but they can not be compared to the speed attained by mag- 
netic tape. For this reason, tape is the most commonly 
used input/output device on the 7O9O, 

Tape may be operated on either high or low density 
mode. In low density , 200 characters are packed to each 
inch of tape. In high density , 356 characters to an inch. 
Tape may be run at high or low speed. Using tape drive, 
model 729-lIf tape passes at the rate of 75 inches per 
second and using tape drive, model 729-IV, it passes at 
the rate of 112^ inches per second. A normal tape is about 
2400 feet long. In low density mode, about 900,000 machine 
words may be put on a reel of tape. In high density mode, 
about 2^ million words will fit on a single reel. This 
should effectively demonstrate the fantastic speeds at- 
tained in the input or output of information utilizing 
tapes . 

The following paragraphs are presented for the 
benefit of those students who have little, or no, computer 
background : 

PLANNING : After an application to be processed is selected, 
it must be thoroughly planned. Planning consists of the 
following steps: 
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1. Analysis oT the application 

2. Plemning and sequencing steps to be used 

3. Writing the instructions 

h. Determining which areas of storage will be used 
for various purposes 

FLO¥ CHARTING ; Before writing machine instructions, it is 
usually advisable to express the necessary steps to be 
talcen in block diagram form. This is called flow charting. 
A flow chart may be quite general or very detailed, de- 
pending on the needs of the prograimner. Generally speak- 
ing, the larger and more complex the problem, the more 
detailed the flow chart should become, 

A flow chart attempts to cover all aspects 
of a problem. Every problem contains a multitude of detail 
which must be ajialyzed, organized and dealt with each in 
its own turn, with nothing left out and nothing forgotten. 
The flow chart is a way of accomplishing this purpose. It 
is also useful in making modifications and corrections to 
programs already written. It is advantageous to use a 
standardized set of symbols so that others may more easily 
interpret a programmers' flow chart. A few of the more 
commonly used signs and forms are shown below. 



Greater Less 
Than Thaji 



Card Tape Printed 

Unequal Input/Output Input/Output Output 



> < 




Processing 
Block 



Decision 
Block 



Connector 
(link to anoth. 
section) 



Direction 
of Flow 



Entries 
and Exists 




O 



6 




V 



dU 
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READING A PUNCHED CARD ; It is not necessary for a fledge- 
ling programmer to be able to read punches on a card as 
fluently as he reads English, but it is necessary for him 
to understand the code used and to be able to decypher the 
punches if it becomes necessary to do so. A punched card 
may contain up to 80 characters of information in a hori- 
zontal line and it has 12 vertical positions. 




SPACE FOR 80 CHARACTERS 



t-!2 PUNCH 
1 1 PUNCH 
PUNCH 
I 

2 
3 
4 

5 
6 

7 
8 
9 



The code is as follows: 

12 PUNCH - 1 PUNCH together in a column = A, 12-2=B, 12-3=C, 
12-4=D, 12-5=E, 12-6=F, 12-7=G, 12-8=H, 12-9=1. 



]% PUNCH - 1 PUNCH together in a column = J, 11-2=K, 11-3=L, 
\ ll-i»=M, 11-5=N, 11-6=0, (slash through indi- 
\ cates it to be alphabetic), ll-TsP, 11-8=Q, 
11-9=R. 

PUNCH - 2 PUNCH together in a column = S, 0-3=T, 0-4=U, 
0-5=V, 0-6=W, 0-7=X, 0-8=Y, 0-9=Z. 

For numeric 1 through 9» punch only the number, omitting 
all three of the top columns. Special characters (i.e. 
comma, period) require special groupings of punches. 

COMPUTER-PROGRAMMER INTERACTION ; Very briefly, this is how 
the system works: The programmer is assigned to do a job. 
He analyzes, flow charts, then programs it on special 
programming work sheets. These work sheets go to keypunch , 
where cards are punched from them. This is called the 
source program . A special program called FAP (Fortran 
Assembly Program ) is loaded into the computer and the 
source program cards are then fed into the computer. Trans- 
lation of the cards into language the machine will under- 
stand is accomplished automatically by the FAP program. 



The new program is then ready for operational use and may be 
left on cards or put on magnetic tape. Vhen operational 
data is ready for processing, the program is loaded into the 

i. ^^^ X^ ^ -t^^^^^ J.-I J^J-» 4« ^ 1 1 ^-.^^J -I . O.. T.TX. . J » J 

does enter, the program takes over ajid processes according 
to the specifications of the job. 

INSTRUCTIONS ; Approximately one hundred instructions will 
be covered in detail in this course. Many instructions will 
not be covered since there is a limit to the size of such a 
course, but the most important, or useful, ones are covered 
and the others may be picked up from the reference manual 
prepared by IBM, entitled, "Reference Manual - 709O Data 
Processing System." 

COURSE FORMAT ; Throughout the course, a small amount of in- 
formation will be imparted, followed by detailed examples 
and problems covering the area of information just covered. 
You are to work the problems in the space provided on the 
problem page amd then check your answers with the correct 
answers given on the following page. 

Pages xiii and xiv will give you an example of 
how this is done, Vork the problems on page xiii to see how 
much you have retained from your reading of pages vii through 
X. When you have finished, check your answers with the 
correct answers given on page xiv. 

Each time you pick up the book, it is a good 
policy to review the portion already covered before starting 
on the new section. It is difficult to retain everything 
you read from one learning session to the next and this re- 
view will help you keep the knowledge already gained. 
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WORK AREA 

Work the problems in this space, then check your answers 
with the correct answers given on the next page. 

PROBLEMS 

A, A sequence of instructions, stored internally by the 
computer is called a ^ r. '■ "■- ■■ . 



B. The three phases of computer processing are 

and 



How many Channels are available to the 7090? 



D. In low density, characters are packed to each 

inch of tape. In high density, ___^_;_ characters 

are packed to an inch. 



E. 



¥hat is the length of a normal tape? 



Define the following flow-charting symbols; 
1. 



2. 




Give the alphabetic representation of the following 
punches in a card: 



1. 12 PUNCH k 

2. PLTNCH k 

3. 11 PUNCH h 
h. PUNCH 2 

5. 12 PUNCH 6 

6. 12 PUNCH 9 

7. 11 PUNCH 1 



8. 





PUNCH 


8 _ 


\ 


9. 


11 


PUNCH 


9 _ 


A 


10. 


12 


PUNCH 


1 _ 


/ ''■ 


11. 


11 


PUNCH 


2 _ 


A, 


12. 





PUNCH 


9 _ 


'2. 


13. 


12 


PUNCH 


2 _ 


■6 


Ik, 


11 


PUNCH 


8 _ 
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CCBEEGT ANSWERS 

A, Program ( see page vii ) 

B. Input, Computation and Outpit (aee page vii) 
G. (see page vlii) 

D. 200 55(> (see page viii) 

E. 24DO feet (see page Tiii) 

F. 1. Processing Blodc (see page ix) 
2. Decision Block (see page ix) 

G. 



(see page 


ix) 






1. D 




8. 


T 


2. U 




9. 


R 


3. M 




10. 


A 


4. s 




11. 


E 


5. F 




12. 


Z 


6. I 




03. 


B 


7. J 




34. 


Q 



If you have answered all of these questions correctly, turn 
the page and start studying Lesson 1, 
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LESSON 1 



DECI>IAL. OCTAL AND BINARY NUMBERING SYSTEMS : The IBM 7090, 
and nearly all other large scale computers, operate on the 
BINARY numbering system. We are all familiar with the 
DECIMAL system, which utilizes 10 digits as its base, but 
many people are completely unfamiliar with the other two 
systems mentioned below. To program for the 7090, it is 
absolutely essential to become familiar with both BINARY 
and OCTAL systems. 

The BINARY system is a base two system, utilizing only 
two digits, zero and one. This is most convenient for com- 
puters because an electrical current may be "on" or "off" 
and a magnetic field may be "magnetized" or "not magne- 
tized". These are also base two types of actions. Since 
computers use BINARY circuits, the internal arithmetic of 
computers is BINARY in nature, 

BINARY numbers tend to be extremely long (roughly 3.3 
times longer than a DECIMAL number). For this reason, a 
shorthand method is used, called the OCTAL system, OCTAL, 
is a base eight numbering system, from zero through seven 
(0-7), OCTAL nvimbers are used when working with the 7090, 
but it must be remembered that the machine itself works in 
the BINARY system. 

The relationship between OCTAL and BINARY is so s-c:*-*^ 
that conversion of numbers from one system to the other may 
be accomplished quite easily. A very complete set of 
tables has been designed to convert DECD-LA-L to OCTAL and 
OCTAL to DECIMAL numbers, but it is not necessary to de- 
pend on these tables as it is fairly simple to make the 
necessary conversion with pencil and paper. Vhen working 
with the computer and large volumes of numbers, the con- 
version tables become very useful. 

On the following pages, each of these two new number- 
ing systems will be examined in detail including some simple 
arithmetic problems. For the time being, we will deal with 
whole numbers (integers) exclusively. Fractions and decimal 
fractions will not be discussed at this time. Fraction con- 
version tables are available in the event that need for them 
should arise. 



Lesson 1, (cont'd) 

BINARY NUMBERING SYSTEM ; Counting in the BINARY system is 
as follows: 



DECIMAL 


1 
2 
3 
k 



BINARY 



1 

10 

11 

100 



DECIMAL 

5 
6 

7 
8 

9 



BINARY 

101 

110 

111 
1000 
1001 



Since the BINARY system only contains and 1, it is 
necessary to take the same "move" at 2, that is taken at 10 
in the DECIMAL system. This is to place a "1" to the left 
and start again with "0". Therefore, a DECIMAL 2 is a 
BINARY 10, 3=11 and then another shift must be made, adding 
"1" to the left and starting again with "0", 

For convenience, BINARY numbers are usually grouped in 
threes ( 001 010 100 ). Consider the BINARY position to 
the right as the "ones" position, then double the number 
for each position to the left (twos, fours, eights, etc.)* 
By using this approach, we can determine the DECIMAL 
equivalent of any BINARY number. 



EXAMPLE ! 



1 







1 







1 





1 


256 


128 


64 




32 


16 


8 




4 


2 


1 






* 
64 




1- 


16 


H 


h 


4 


+ 


1 = 



85 



Add together all numbers 
that have BINARY 
Disregard "0". 



A DECIMAL "7" is written as BINARY 111 {h + 
A DECIMAL "15" is written as BINARY 001 111 



2+1=7) 
(8 + 4 + 2 + 

= 15) 



Rather than referring to the three systems by name, it 
is more convenient to designate any number with the system 
being used, as follows: 



DECU-IAL 11 will be written 11 



10 



OCTAL 



11 will be written 11 



8 



BINARY 11 will be written Ollg , but it is obvious by 
inspection if a number is written in BINARY, as it usually 
consists of a long series of zeros and ones. 



Lesson 1, (cont'd) 



¥ORK AREA 



Vork the problems in this space, then check your answers 
with the correct answers given on the next page. 



PROBLEMS ; 



1. Convert 17-, q to BINARY notation. 



2. Convert 18, „ to BINARY notation. 



3. Convert 26 „ to BINARY notation. 



lO 


c3e>i 




lO 


OlQ\ 




li 


Oio 



The following B±NAkY figures convert to what 
DECIMAL figures? 



a. 000 001 

b. 010 101 

c. 001 Oil 

d. 001 010 

e. 010 100 

f. 001 001 001 

g. 001 010 100 



^-/ 



// 



}6 






Convert 233^^^ to BINARY notation. 



"^77~T^~mrT 



Lesson 1, (cont'd) 

CORRECT ANSWERS 

1. 010 001 (l6 + 1 = 17;lo) 

2. 010 010 (l6 + 2 = 18^q) 

3. Oil 010 (l6 + 8 + 2 = 26^q) 
k. 



a. 


1 






b. 


16 


+ 


h . 1 = 21^0 


c. 


8 


+ 


2.1= 11^^ 


d. 


8 


+ 


2 = ^^10 


e. 


16 


+ 


^ = 20^0 


f. 


6ii 


+ 


8.1= 73^0 


g. 


64 


+ 


16 + 4 = 84,, 



10 
5. oil 101 001 (128 +64+32+8+1= 233 ) 

As you can see from problem 5, when the number gets 
fairly large, it becomes quite difficult to convert in this 
manner. This is one of the reasons why OCTAL is used as an 
intermediate step between DECIMAL and BINARY, 
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BINARY ARITHMETIC; 



Only a few rules need to be observed to 



accompxisn sxmpie arxrnmerxc m axjNAKi lorm. 



ADDITION : 



Rule 


1: 


Zero plus zero equals zero. 


Rule 


2: 


Zero plus one equals one. 


Rule 


3: 


One plus one equals zero with a carry 
of one to the left. 



EXAMPLE : 



Add 



^5io ^ 7^0 



(column) sixteens eights fours twos ones 



(carry) 



In the 
"twos" column. Rule 
add the "carry", so 
same thing happens 
column, Rule 2 appl 
so now Rule 3 takes 
"carry". In the "s 
add the "carry", wh 




ones" column. Rule 3 applies. In the 



3 applies again, but we must further 
the result is 1 with a "carry". The 

in the "fours" column. In the "eights" 

ies, but again we must add the "carry", 
over and we end up with zero and a 

ixteens" column, Rule 1 applies, then 

ich winds it up with a 1. 



SUBTRACTION ; 



Rule 1 
Rule 2 
Rule 3 
Rule h 



Zero minus zero equals zero. 

One minus one equals zero. 

One minus zero equals one . 

Zero minus one equals one, with one 

borrowed from the left. 



•^^10 " ''lO 



EXAMPLE : Subtract 

( c o lumn ) sixteens eights fours twos ones 








1 




1 
1 



1 

1 



1 
1 



[borrows) 
'10^ 











(= 8,^) 



10^ 



Applying the rules above, in the "ones" column, 
Rule 2 applies. Also in the "twos" and "fours" columns. 
In the "eights" column. Rule 3 applies. In the "sixteens" 
column, Rule 1 applies. 

Similar, but somewhat different rules are used 
for multiplication and division. They are nothing more 
than sequences of addition and subtraction, extremely cum- 
bersome with paper and pencil, but very rapidly accom- 
plished with the high speeds attained by modern computers. 
This page demonstrates the way arithmetic is actually 
accomplished within the computer. 



Lesson 1, (cont'd) 



EXAMPLES : 



1. Add: 3^0 + 3^0 



fours twos ones 




1 1 {k + 2 = 6) 

In the "ones" column, Rule 3 applies. In the "twos" 
column, two steps must be taken; first, 1+1=0 with a 
carry; second, the (resulting from the first step) + 1 
(from the previous carry) =1, In the "fours" column, two 
steps must be taken; first, 0+0=0, second, this 0+1 
(from the previous carry) = 1. Each time there is a "carry", 
the second step must be taken. 



2 , Add ! 



k +3 
10 -^10 



fours 


twos 


ones 


1 











1 


1 



(carries) 

(^) 
(3) 



(i+ + 2 + 1 = 7) 



3 . Add ; 



7io -^ ^10 



eights fours twos ones 








1 
O 



(8 



(carries ) 

. [I] 

4 + 1 = 13) 



h. Subtract: 12 



,^ - 4,„ eights fours twos ones 

^ borrows; 
1 1 (12) 
1 (if) 











( = 8) 



5, Subtract: 12 - 7 



10 



10 



eights fours twos ones 

'1 ^-1 (borrows) 



i Tl^k + 1 = 5) 

In the "ones" column. Rule k applies, but since there is 
no "1" to borrow in the "twos" column, we must get it from 
the "fours" column, changing the 1 to a in the "fours" and 
the to a 1 in the "twos". In the "twos" column, Rule 2 
applies. In the "fours" column, 0-1 causes a "borrow" from 
the "eights" column, leaving it a 0, which results in for 
the final subtraction. 



Lesson 1, (cont'd) 

WORK AREA 

Vork the problems in this space, then check your answers 
with the correct answers given on the next page. 

PROBLEMS 

6 , Add : sixteens eights fours twos ones 

(carries) 
1 1 f9^ 
+ 1 1 (6) 



Result: £ / I j ; 

7 • Add : sixteens eights fours twos ones 

(carries) 

1 10 1 (25) 

+ 1 1 (6) 
Result: | ; ■ 

8 . Add : sixteens eights fours twos ones 

! (carries) 

1 10 (10) 

+ O 1 1 1 (7) 

Result: I ,f) <: ^^ \ 



9. Subtract: 

sixteens eights fours twos ones 

^ f (borrows) 

:k '0 1 (9) 

- 1 1 (6) 



Result: ^ 

10. Subtract: 
sixteens eights fours twos ones 

(borrows) 

;25) 

6) 
Result: J J 5 ,.: /" 

11. Subtract: 

sixteens eights fours twos ones 

(borrows) 





c 


i 






1 


^ 








1 








1 


1 






"> -to 1* no) 
1 1 1 (7) 



Result: (J r ' f 



Lesson 1, (cont'd) 

CORRECT ANSWERS 

6» sixteens eights fours twos ones 

(carries ) 
1 O 1 (9) 

+ g 1 1 (6) 

Result: 1 1 1 1(8+4+2+1=15) 

7. sixteens eights fours twos ones 



1 1 1 ^25) 
_0 1 1 ( 



(carries) 
25 
6) 



Result: 1 1 111 

(16 + 8 + 4 + 2 + 1 = 31) 

8» sixteens eights fours twos ones 

1 ■^-— __ /I > -♦-_ >/r> (carries) 



+ t > ifij ^jJ ^1 1 



m ^gJ ^3- L_ 7) 

Result: 1 1 (l6 + 1 = 1?) 



9. sixteens eights fours twos ones 

y\. jT'^ (borrows) 

<:o\i— »► < rsQ '^^ 1 (9) 

- ^ 1> 1 (6) 

Result: 1 1 (2+1=3) 

10, sixteens eights fours twos ones 

^1 (borrows) 

1 <o\i — »-<1\q ^^ 1 (25) 

- k — 1^ i 0_(6) 

Result^ 1 1 1 (16 + 2 + 1 = 19) 

11. sixteens eights fours twos ones 

^,,jr^ j^'l (borrows) 
<^ ^<1\D^<0\1 ""^^ (10) 

- ^^1 ^ ^^ L_ 7) 

Result^ 1 1 (2 +1 = 3) 



8 



Lesson 1, (cont'd) 

OCTAL NUMBERING SYSTEM ; This is a base 8 system, using the 
digits from through 7« Counting in the OCTAL system is as 

follows (notice that "8" and "9" are never used): 



DECIMAL 

1 
2 

3 

k 

5 
6 

7 



OCTAL 


1 
2 

3 
h 

5 
6 

7 



DECIMAL 



OCTAL 



8 


10 


9 


11 


10 


12 


11 

12 


13 
Ik 


13 

14 


15 
16 


15 


17 


BINARY is 


so s: 



that conversion may be made instantaneously. Consider every 
BINARY number in groups of threes (OOIOIOIOI = 001 010 lOl) . 
Now, each grouping of three BINARY digits is identified by 
"ones," "twos," and "fours" positions and these are used to 
convert to OCTAL, as follows: 



fours twos ones 



O 







fours twos ones fours twos ones 







0. 



2 



5 



OCTAL 



EXAMPLES ; 



1 . Binary : 
Octal: 



Oil Oil 010 111 
''^ \^ \y \^ 

3 3 2 7 



Binary: 10 010 
Octal: 2 2 



Binary: 100 010 110 
^^ ^^ ^>^ \^ 
Octal: 4 2 6 



If the Binary digits do not 
come out in groups of "three", 
add zeros to the left until 
the final group also contains 
three digits. 



Lesson 1, (cont'd) 

CONVERTING FROM OCTAL TO DECIMAL : This is usually accom- 
plished by looking up the number in a conversion table (see 
7090 Reference Manual, Appendix B and C). It may be accom- 
plished manually in the following manner: 

Multiply each Octal position in turn by 8, starting 
with the high-order (left-most) position. Then, add the 
next number to the result, until the last digit is reached 
(this one is not to be multiplied). 



EXAMPLE 1: 



33278 = 



10 



33273 
X 8 

+ y 



27 

x_8 
216 

218 
X 8 

1744 

11 



1751.,, Result (3327o = 



10 



8 



1751^0) 



EXAMPLE 2; 



^2^8 = ^0 



426 
8 



32 

r 2J 



34 

I 8 



272 
+ G^ 



8 



278^„ Result (426q = 



10 



8 



278^^) 



10 



Lesson 1, (cont'd) 

CONVERTING FROM DECIMAL TO OCTAL : This procedure is also 

but it may be done manually in the following manner: 

Successively divide the decimal figure by 8, until no 
further division is possible. The Octal result will be the 
last quotient figure, followed by each of the remainders, 
starting from the last and finishing with the first. 



EXAMPLE 1: 



I75I10 = ?8 



218 




Result ; 



1751^0 = 33278 



EXAMPLE 2 



278 



10 



= ? 



8 




Result: 



27810 = ^^S 



EXAMPLE 3: 




Result: 15273j^q = 35651 



8 



11 



Lesson 1, (cont'd) 

¥ith what we have learned to this point, it becomes 
obvious that it is not necessary to add or subtract in 
BINARY form. Simply convert to OCTAL and from OCTAL to 
DECIMAL before doing the arithmetic operation. 

EXAMPLES : 



1. BINARY 

010 111 
+ 110 010 



CHANGE TO OCTAL 
2 7o 



6 2 



CHANGE TO DECIMAL 

62 
X 8 



27 
x_8 
16 

+JZi 

23 



48 
+ 2- 

50 



2 3 

5 o 



10 
10 



7 3^Q Result 



2. 



3. 



BINARY 


CHANGE TO OCTAL 


110 010 




6 2 

? 


010 111 
? 


- 


BINARY 


100 


CHANGE TO OCTAL 


001 010 


1 2 4« 
.115^ 


001 001 




101 



CHANGE TO DECIMAL 



5 O 
-23 



10 
10 



2 7 Result 



CHANGE TO DECIMAL 



124 
X 8 

8 
+ 2J 

10 
x__8 

80 

8k 



115 
8 



X 

X _ 

8 
+ _1J 

9 

X _8 

72 
+ _1-J 

77 



8 h 
+7 7 



10 
10 



1 6 1 



10 
Result 



To set up a BINARY number (starting with a DECIMAL 
number) , convert in the other direction. 



4. 956, 



= ?, 



10 " "2 

DECIMAL CHANGE TO OCTAL 




WRITE THE OCTAL OUT IN BINARY FORM 

100 

h 
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Lesson 1, (cont'd) 
PROBLEMS : 

= ? 



12. 565 



10 
Result : 



8 



\ 



13. 5658 = ?io 
Result : 



Ik 12U2 = f 



Result 



15. 010 101 110 = ? 



10 



Result 



16. 135^0 = ? 8 
Result : 



17. 1358 = ^0 
Result : 



r 



18, 111 100 001 = ? 



8 



Result : 



19. Result of problem 18 =? 



Result : 



10 



WORK AREA 

Vork the problems in this 
space, then check your an- 
swers with the correct an- 
swers given on the next page. 
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Lesson 1, (cont'd) 



12. 1065 



8 



CORRECT ANSWERS 
70 



8 



13. 373 



8 J 565 8 ("70" 
56 64 
5-« 6- 



10 



1 
8j~8 

8 
0- 



Ik. 010 Oil Oil 010 (2332jj) 



8^ 



15. 174 



10 



16. 207 



8 



17. 93 



10 



18. 74l, 



19. 481 



10 



14 



LESSON 2 



MACHINE WORDS ; The Memory , or Storage Unit , of the 709O 
contains space for 32,768 machine words. The term word, 
refers to a unit of information. It may be aji instruction 
to the machine or a piece of data which will be processed 
by the machine. The 7090 is a fixed word length machine. 
This means that every machine word is exactly the same size 
as every other word. The words are numbered from 00000 
through 32,767 and each word may be called upon by the pro- 
grammer. This is termed addressing a word. The word it- 
self is 36 positions (binary bits ) in length and may be 
shown symbollically in the following manner: 



Q 



f 



_j I i — t I t_ 



I 23456789 10 II 12 13 1415 16 17 18 192021222324252627282930 3132333435 
SIGN 
(+0R-) 

A "zero" in the sign position indicates "+", A "one" indi- 
cates "-". This leaves 35 positions, or Binary bits , for 
the word itself. 



WORK AREA 

Work the problems in this space, then check your answers 
with the correct answers given on the next page, 

PROBLEMS : 

20. Convert 32,767 _^ to Octal . Result: 



10 



21, A machine word is always f positions in length. 

22. Each word may be .-' ■: ■- ■ ' '- -■ by the programmer, 
23 • Convert the result of problem 20 to Binary . 

Result : 



2k, A plus sign (+) is always designated by a 
Binary ';^ . 

25, A minus sign (-) is always designated by a 
Binary '. , 

26. Machine words are nxombered from _. through 



27, A word may be either an '■ to the 709O, or 

a piece of -. ' . 

15 



Lesson 2, (cont'd) 



CORRECT ANSWERS 



20. 777778 



21. 36 

22. Addressed 

23. Ill 111 111 111 111 

24. O 

25. 1 

26. 00000 through 32,767 

27. instruction data 



If any of your answers were incorrect, please turn 
back to page 15 and read it over again. 
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Lesson 2, (cont'd) 



REGISTERS ; There are several registers in the Central Pro - 
cessing Unit (CPU) of the 7O9O, which are used for specific 
processing actions, A brief description of each register 
will be given here. 

1. AC (Accumulator) and MQ (Multiplier-Quotient) Registers: 

All arithmetic operations are handled through these two 
registers, A great deal more will be said about them later. 
S3nnbolically represented, they look like this: 



AC r-, MQ 



-H 

iBT I 2 



f' 1' , 'j,' ■ — ' I ■ — I — I 1 T" 1 1 — I — 1 1 I I 1 

4 I 2 35T I 2 35 

FIRST OVERFLOW POSITION eiRiu 
SECOND OVERFLOW POSITION 

SIGN (this is a 38 bit register) (36 bit register) 

These two registers may be considered to be working to- 
gether, with the MQ as the right-most extension of the AC, 

2, SI (Sense Indicator Register): 

It is possible to manipulate individual bits in this 
register, using them as switches. 



I 2 3536 

(36 bit register) 

3. XR (index Registers) : 

There are three Index Registers, which are referred to 
as XR 1, XR 2 and XR kt Index Registers are extremely use- 
ful to count or decrement sequences of numbers and to move 
the progreim to subroutines and back to the main program Qx>m 
subroutines. 



I 2 1415 

(15 bit registers) 

All of the registers will be discussed in detail as 
they become useful in programming. There are other regis- 
ters which are not mentioned here because, although they 
are necessary for machine processing, they are not appli- 
cable to programmer manipulation. These registers are the 
Storage Register and Instruction Register . 
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Lesson 2, (cont'd) 

AC AND MQ REGISTERS ; All arithmetic operations are handled 
through these two registers. 

Addition and Subtraction : These operations always take 
place in the AC and since the result may be larger than 
each of the figures being added or subtracted, positions 
"P" and "Q" are provided for any overflow that may occur. 

One of the niombers (to be added 
or subtracted) is moved into the AC, going into the right- 
most portion of the register. Any unused portions would be 
filled with zeros at this point in time. 

EXAMPLE: Move ^^260 into the AC 






u 










t 








_l 1 1 L. 


'.0.'. 


1 







SQ P I 2 3 2728 29 30 31323334 35 

-^ -- -- 

Then the add (or subtract; in- 
struction is given, addressing the storage position where 
the other number is located. This will add (or subtract) 
into the number already stored in the AC, The result then 
may be moved from the AC to a specific location in storage , 
eind further processing may continue. 

Multiplication and Division : In these operations, the MQ 
is considered to be attached to the AC, to form a 72 bit 
register (not counting the sign positions). In multiplica- 
tion, the most significant* half of the product will be in 
the AC and the least significant half in the MQ. In divi- 
sion, the remainder will be in the AC, while the quotient 
will be in the MQ (including the sign). These operations 
will be discussed in much more detail later in the course. 

Plus zero and Minus zero : It is quite often necessary to 
compare the number in the AC with a number in storage to 
determine whether the ntimber in the AC is less than (•■=^), 
equal to ( = ) or greater than (^^^=*) the number in storage. 
In these comparisdns, it is important to understand that 
the computer considers +0 as greater than -0. 
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Lesson 2, (cont'd) 

¥ORK AREA 

Work the problems in this space, then check your answers 
with the correct answers given on the next page. 

PROBLEMS ; 

28. Most of the registers used in the 7O9O, are 

positions in length, containing one position for the 

3-nd additional positions for the 

machine word . 

29. Which register has two additional positions? 

30. These two additional positions are used to take care of 
^^ and operations, 

31. How many positions does an Index Register have? 

32. The three Index Registers are called 

and 



33. Identify the following signs: 



a. 



3^. The _, Register must be used for addition or 

subtraction. 

35. In multiplication, the most significant half of the 
product will be in the Register, 

36. In division, the quotient will be in the Register. 

37. Add the following figures, sind show the result in the 
AC, Also show the sign: 

24^ 

? 



n 



.-^ I ,N, ^^ ^ . f) ! ^1 ill 



^ Q P ' 2 20 21222324252627282930 3132333435 
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Lesson 2, (cont'd) 

CORRECT ANSWERS 

28. 36 sign 35 

29. Accumulator (ac) 

30. overflow addition subtraction 

31. 15 

32. XRl XR2 XR'* 

33. a. Greater than 
b. Less than 

34. AC 

35. AC 

36. MQ 

37. ^27- 
^10 



10 
376^ 

2kk^ 



10 



10l47io = 20278 







,, 



o-« ^ ^0 I I I I I 

I I I ' I I I I I — I — I — 1—1 — I — I — I — 1 — 



i 2 a»2526E72829303l 323334 35 



The sign is plus (+) unless indicated otherwise. 
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An instruction word consists of 35 









Lesson 2, (cont'd) 

FORMAT OF INSTRUCTIONS ; 

Binarv bxts ojid a. «-io*ti- 

which is named and performs a specific function. ^xx^^c dj. c 

five major groupings of instructions which will be referred 

to as Type A,_B, C, D and E. There are also three formats 

used by the ^ (discussed on page viii)^ which will be shown 

at a later time. 



, cacii ux 
There are 



TYPE A INSTRUCTION FORMAT 



OF 
CODE 



S,l,2 



DECREMENT 



TAG 



ADDRESS (Y) 



n 



. -I-.- - . 17 18-2021 35 

OP. CODE (Operation Code) ; This is always a 3 digit code 
found at the beginning of the word, as shown above. It 
tells the machine what operation is to be performed. 

DECREMENT : This field is used for a group of instructions 
which test or change the contents of an Index Register. 
(To be discussed in detail later in the course.) 

TAG: These 3 digits are used to identify the Index Register 
to be used (if any). (These will be discussed in detail 
later in the course.) 



001 = XRl, 010 = XR2, 



100 = XRk 



ADDRESS ; This is the location in storage of the data to be 
used with the instruction. This will be referred to as c(y) 
(contents of Y - "Y" being the storage address where the 
data may be found) when discussing the various instructions. 

TYPE B INSTRUCTION FORMAT 



OP CODE 



OP. CODE: 



S,l 



lA 



II 12-13 






TAG 



IF 



ADDRESS (Y) 



2021 35 

In this type instruction, Op. Code includes the 



sign and the first 11 positions. 

IND. ADDR. (indirect Addressing) ; This deals with address 
modification , as do the Index Registers. This will be dis- 
cussed in detail later in the course. If "one" bits are in 
both positions 12 and 13, this is known as a flag for in- 
direct addressing, 

TYPE C INSTRUCTION FORMAT 



OP CODE 



S,l 



COUNT 



9 10 



TAG 



ADDRESS (Y) 



OP. 



1718-20 21 35 

CODE: In this type instruction, Op. Code includes the 



sign and the first 9 positions. 

COUNT: This area contains bits which are tested during the 
execution of an instruction. More detail will be furnished 
as instructions of this type are used. 
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Lesson 2, (cont'd) 



TYPE D INSTRUCTION FORMAT 



OP CODE 


'msm, 


MASK OR CONTROL 



S,l II 18 35 

MASK ; The Sense Indicator (Sl) instructions use the ad- 
dress Eind tag fields as a mask . More detail on this later 
in the course. 

TYPE E INSTRUCTION FORMAT 



OPCODE 



iUSED 



TAR [NOT/y 



OP CODE 



S,l II 18-20 24 35 

OP . CODE : In this type, Op. Code includes not only posi- 
tions S and 1-11, but also positions 24-35. It is most im- 
portant when using Type E instructions, not to place any- 
thing into what is normally the address portion, as this 
would have the effect of changing the Op. Code. 

All of these instruction formats seem very confusing, but in 
reality a little further study will help to clarify them to 
a certain extent. Actual use of the various instructions 
will do more them anything else to straighten them out in 
the mind of the student. As the function of each instruc- 
tion becomes clear, the various parts will also become clear 
as to use and function. 

EXCEPTIONS ; In one Type A instruction, positions 3-35 are 
not used. In one Type C instruction, the grouping of the 
bits is slightly different from that shown in the format. 

The Op. Code always contains a sign (+ or -) and the binary 
code which tells the machine which operation it is to per- 
form. For example: ADD, would be +00100000000 in binary 
form. It is more convenient to write this in octal: +0400. 
TRANSFER ON INDEX LOW would be: - 11000000000. In Octal: 
-3000. 

Type A instructions (in Octal) always have a single 
non-zero digit, followed by three zeros. These zeros may be 
covered up by the decrement portion of the instruction with- 
out losing the instruction. Since the first Octal digit of 
the Op. Code is represented by only two Binary digits, 
Type A can only include 1000, 2000 and 3000 (also may be 
-1000, -2000, -3000). All other Op. Codes start with a zero 
after the Sign position and these are never Type A instruc- 
tions . 

Type B instructions may be distinguished by the fact 
that no part of the instruction is used for testing or 

control. 

Type C has a "test" area in positions 10-17 . The Octal 
representations of these instructions must end in 4, so that 
the last two digits will be zeros which may be overlapped 
by the Count field. 

Type D has a "mask", or "control", area in the entire 
second half of the word, from 18 through 35. 

Type E is easily distinguished from the others as the 
Op. Code is in two separate parts of the woid (S, 1-11 and 24-35). 
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Lesson 2, (cont'd) 

Not only does the 709O have several different instruction 
formats, but it also has well over 150 different instruc- 
tions. It is not necessary to memorize all of the instruc- 
tions. The IBM 7090 Reference Manual lists all of them, 
including their Octal codes. About one-third of the in- 
structions are basic and most commonly used. The greatest 
stress will be placed on the.se instructions throughout this 
course. 

One final point before looking at some of the actual in- 
structions. Although each type of instruction contains 
several parts , they are not all used in every instruction. 
For example, the Tag portion may be used if an Index Regis- 
ter is involved. Otherwise it is disregarded. In most of 
the instructions, the Address (contents of storage location 
Y) is needed so that the computer will know where to go to 
get the data that is to be processed and all instructions 
must have an Operation Code , so that the computer will know 
what operation to carry out. 

Example of an instruction as it would look in storage: 



ADD 2 1^^ This means, "Add the contents of storage 
location 2 l-.„." 



ADD = +0400 



2 ^10 = 2 58 



Example 2: 
SUB 579j^o 



SUB = +0^102 



579io = 11038 



OP CODE 



lA 



TAG 



00100000000 
''■'■'''■■ 



ADDRESS (Y) 



00 00 000 10 1 1 



000000 000 

— ' — I — ' — ' — I — I — I — I — I — I — I 1 I I I ■ ■ 

18 2021 35 



•^ v_^ ^-^ ^1 1213 
+ 4 

(Type B Instruction) 

This means, "Subtract the contents of 
storage location 579to*" 



OP CODE 



lA 



TAG 



001 00000010 

■1—1 — 1—1 — i — i— i_i I . 



00 



ADDRESS (Y) 



00 



00 



18 2021 



vj^ ^_x ^^ 0"2'3 
+ 04 02 

(Type B, Instruction) 



000 001 001 00001 I 

■I — I ' ' — I — ' — 1— 1 — 1 — 1—1 — 1 .—I 



35 
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Lesson 2, (cont'd) 

Additional Examples ; The meaning of these instructions is 
not important at this time, 

3. Instruction: XCA (+OI31) 
S 



1-0 



OP CODE 



MASK 



1000 I 01 100 1 
..I I I I I — I — I — I — I— 



0*- 



-1 — I— I — I — I — I — 1—1- 



-» 



' ■ I I 1 I — I — I — I — L. 



^ ^^ N--- O' '2 

+ 01 31 



35 



(type d instruction) 



4. Instruction: RND (+O760) 



OP CODE 




OP CODE 




00 1 1 h 1 1 000 
_i— 1 — I— 1 — i — 1 1 1 — 1—1 — 






— 1 L_l 1 1 ■ 1 1 1 1 1 


1 1 1 — 1 — 1. .1. ..1 1 1 L...1.. . 



vi-' v_^ v_^ v_j' 
+ 07 6 



24 



35 



(type e instruction) 



5. Instruction: CRQ (-0154) 



OP CODE 


COUNT 


TAG 


ADDRESS (Y) 




00 00 1 1 1 .1 

1 1 l_l 1 1 1 L_ 








1 1 1 1 1 1 1 


• ■ 


1 1 1 1 1 1 1 J 1 1 1 1 1 1 



dy ^^ ^ VB^ 
15 4 



1718 2021 



35 



(type c instruction) 



6. Instruction: MPY (+0200) Storage location 705 



8 



OP CODE 


lA 




TAG 


ADDRESS (Y) 




OOOJ 0_00 000 


r\ ^ 








1 




I ■ 1 




- 1 1 J- 1 1 1 1 1 1 1 -X..,l 



vj^ v_^ ^^ V_III2I3 
+ 2 



18 2021 



.35 



(type b instruction) 



7. Instruction: TIX (+2000) Storage location 117g 







OP 




DECREMENT 


TAG 


ADDRESS (Y) 


1 








1 ■ 1 1 1 1 1 1 1 I 1 1 1 1 




1 1 1 1 I ■■ 1 1 ■ 1 1 1 1 



I 2 3 

+"2 



1718 2021 



35 



(type a instruction) 



I I 



2h 



Lesson 2, (cont'd) 

WORK AREA 

Vork the problems in this space, then check your smswers 
with the correct answers given on the next page, 

PROBLEMS ; Write the instructions and addresses into the 
words below. 



38. Instruction: HPR (+0^20^) Type D instruction, 
S 



'8^ 



OP CODE 



MASK 



)4 ':^)''rj'0^ 



I 



1112 



35 



39. Instruction: HTR (+0000,,) Storage location 215, „ 
Type B, ° 1" 



13 



OP 



TAG ADDRESS 



2^5io =^8 



D\10'3\" 



18-20 21 



35 



kO. Instruction: STL (-0625s.) Storage location 57 



Type B, 
S 



8^ 



10 



1 

I 


OP 




TAG 


ADDRESS 


ooi\^\rm 









57io = ^8 



I 



18-2021 



35 



4l. Instruction: CLA (+0500j,) Storage location 2 



Type B. 
S 



8' 



"10 



rj 


OP 




TAG 


ADDRESS 






V-^j ■;:■,-:- ■.-, 






) '^ '.^ 


'j 



^10 - "^8 



II 



18-2021 



35 



42, Instruction: NOP (+076lg) Type D instruction, 
S 



-^ 


OP 




MASK 


OD ' J I 


:,to1 





1112 



35 



^^3. Instruction: TXH ( + 3000q) Storage location 9 



Type A, 



8^ 



10 



s 


OP 


DECR 


TAG 


ADDRESS 


L_ 


I: 






■» 'ii t% \ 



^10 T-, "^8 



123 



1718-2021 



35 
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Lesson 2, (cont'd) 



CORRECT ANSWERS 



38. 



S 



OP 



00 I 0001 0000 
■ I I I I I I I I — t 



39. 



+ 4 2 

215io = 3278 



kl. 



s 




OP 




ADDRESS 


00000000000 
_J 1 I...J..J.-1. l._l. 1_1_ 




1 1 1 1 1 1 



^0. 57 



10 





= 7l8 



II 



- 6 
^10 "" ^8 



21 



21 



35 



s 

1 




OP 






ADDRESS 




00 1 
1 > 


1 1 
1 II 1 J J 


01 




1 II 1 

1 1 1 ■ 1 ■ 



35 



h2. 



s 






OP 




ADDRESS 






00 1 
1 1 


01 00 000 
-I 1 — 1 — I — I — 1 — 1 — I— 













+ 



21 



35 



^3. 








OP 




1 


1 1 1 00 01 
1 i 1 1 1 II 





I 

+ 

9 



1 1 



10 



7 6 
1^8 



S 




OP 




ADDRESS 




1 1 




00 
1 III 


100! 



I 2 
+ 3 



21 



35 



I I 
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LESSON 3 



FIXED POINT NUMBERS ; When it is easy to determine where a 
decimal point is to be placed in an arithmetic operation, 
fixed point instructions are used, A fixed point number 
contains a sign and 35 bit positions containing the number 
itself. 



I 



iO 



20 



_i ' ' ' ■ 



-*-0 I 00 
I—I — ). - • 



32335435 

4 
When fixed point operations are used, it is up to the pro- 
grammer to decide where the decimal point is to be placed. 
The point that separates the whole number from the fraction 
is called a binary point , 



(+^.28) 

It is called fixed 



20 



I I I I ■ ■ 



100010 



3Q3I32333435 

. ^ ^ BINARY POINT 

jomt because the programmer determines 



the positioning of the point, as opposed to floating point , 
in which the point is automatically maintained by the com- 
puter. 



BASIC FIXED POINT OPERATIONS ; 

INSTRUCTION; CLA (Clear and ADD) Octal code: +O50O 



FORMAT ; (Type B) 



OPCODE 


lAMWiTAG 


Y 



S.i 



! 112-13 



18-20 21 



35 



Description ; The c(y) replace the c(ac). This means, "The 
contents of storage location, specified as Y, replace the 
contents of the Accumulator." Always specify the address 
of the piece of data, or information, that is to be moved. 
This tells the computer to move whatever it finds at that 
address. Positions P and Q are set to zero and the c(y) 
remain unchanged. 

INSTRUCTION; ADD (Add) Octal code; +0^00 
FORMAT ; (Type B) 



OPCODE\lAy/////////JiTAG 



S,l 1112-13 18-2021 35 

Description ; The c(y) are added algebraically to the c(ac) 
and the sum is placed in the AC. The c(y) remain unchanged. 
Numbers of the same magnitude , but with different signs 
(+2, -2; +407, -407) will result in zero with the original 
sign of the AC. 



Examples of algebraic addition; 

+ 5 +3 



SUM: 



+5 
+3 

+8 



-5 
-3 

-8 



+5 (Y) 



-5 (Y) 



+2 



-2 



-0 



+0 



AC) 
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Lesson 3» (cont'd) 



Example 1 ; 





SI 

+ 



CLA 25 (This means, ••Clear the contents of the 
AC and place the contents of storage word 25 
into the AC") 

If the c(y) (storage location 25) = 2573o, after 
execution of the instruction the AC would look 
like this: 



Wp 



0-i — 

.1 I I 



",0,1,0 10. I.I ,1. 1.0, I.I, 
24fe^6^i*'fe'29303l32^33435 



V "T T -r 

Now that we have a number in the AC, we can add 
another number to it. ADD 2? (This means, "Take 
the contents of the word at 2? and add it to the 
contents of the AC."1 

If the c(y) (storage location 2?) = 12g, after 
execution of the instruction the AC would look 
like this: 



25738 = 1^03^0 



128 = + 



10 



10 





s 





1413^0 = 26058 














1,00.0,0, 


1 








."-'>' 



Q P I 



ExEunple 2 ; 



Step 1: 
Step 2: 



Storage Location 

15 
22 



242526Z72829303I32333435 
2^05 
Data in Storage 

257, 



173 



8 
8 



Add the two numbers together. 

Move c(l5) into the AC with the CLA instruction. 
Add c(22) to it. Sum of the two numbers will 
be in the AC, 

To get the sum (with pencil and paper) that will 
finally be in the AC, we must convert: 



INSTRUCTIONS : 



2578 


= 175io 


1738 


= 123^0 




= 298^0 


CLA 


15 


ADD 


22 



= U52 



8 



(change the Octal to 
Decimal - add - 
then change the sum 
back to Octal) 



Contents of the AC after execution: 





S 



0|0 



Q P I 



I I I I 

■■■■■'■ L 



272829303132333435 
4 5 2 
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Lesson 3» (cont'd) 

INSTRUCTION ; SUB (Subtract) Octal code: 
FORMAT ; (Type B) 



+0402 



OP CODE 



lA 



wim 



TAG 



S,l 1112-13 18-2021 35 

Description ; The c(y) are algebraically subtracted from the 
c(AC) , The difference replaces the c(ac). The c(y) remain 
unchanged. 

Examples of algebraic subtraction: 



-5 +5 
+2 -3 

Diff:-8 +8 


+ 5 

+3 
+2 


+3 
-2 


-5 
-2 


-3 +3 -3 
-5 -? +? 

+2 +8 -8 


-2 

-2 
-0 


+2 
+2 
+0 


INSTRUCTION: 


MPY 


(Mult 


iply) 


Octal code: 


+0200 





FORMAT: 



(Type B) 



OP CODE 



lA 



^IJAG 



S.l 1112-13 18-2021 35 

Description ; The c(MQ) are multiplied algebraically by the 
c(Y) , The product replaces the c(AC and MQ) with the most 
significant 35 bits in the AC and the least significant 35 
bits in the MQ, Overflow is not possible and the product 
is positioned to the right with enough leading zeros to 
completely fill both registers. 

Sign Control for algebraic Multiplication 
Sign of multipliceoid + - + - 
Sign of multiplier + + - - 
Sign of product + - - + 

INSTRUCTION : DVH (Divide or Halt) Octal code: +0220 
FORMAT : (Type B) 



OP CODE 


lA 


w/m 


TAG 


Y 



S, I I 1 12-13 18-2021 35 

Description : The c(AC-MQ) are divided algebraically by the 
c(Y) . The quotient replaces the c(MQ) aind the remainder re- 
places the c(AC), If division can not take place (ex: di- 
visor of zero) , the computer halts and a "divide-check" 
indicator turns on. The dividend must be placed into the 
AC-MQ prior to giving the DIVIDE instruction. If it oc- 
cupies only one register, the programmer must clear the 
other, by placing zeros into it. 

Sign Control for algebraic Division 
Sign of divisor + + - - 
Sign of dividend + - + - 
Sign of quotient + - - + 
Sign of remainder + - + - 



INSTRUCTION ; STO (store) Octal code: 
FORMAT : (Type B) , 



■0601 



OPCODE 



lA 



TAG 



S.l 1112-13 I8^^202r 35 

Description : The c(ac) replace the c(y). The sign and bits 
1-35 of the AC move into the storage location specified by 
(y). The c(AC) remain unchainged. 
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(Load MQ Register) Octal code: +O56O 



OP CODE 


lA 


w§, 


TAG 


Y 



Lesson 3» (cont'd) 

INSTRUCTION ; LDQ 
FORMAT ; (Type B) 



S.I 1112-13 18-2021 35 

Description ; The c(y) replace the c(MQ). The bits at the 
address (Y) move into the MQ. The c(y) remain unchanged, 

INSTRUCTION ; STQ (Store from MQ Register) Octal code:' -O6OO 
FORMAT: (Type B) 



OP CODE 



lA^ 



TAG 



S.I 



1 1 12-13 



18-2021 



35 



Description ; The c(MQ) replace the c(y). The bits in the 
MQ move into the storage location specified by (y) . The 
c(MQ) remain unchanged. 



INSTRUCTION ; HTR (Halt or Transfer) Octal code: +0000 
FORMAT: (Type B) 



OP CODE 


lA 


» 


TAG 


Y 



s,i 



1112-13 



18-2021 



35 



Description ; When this instiniction is executed, the com- 
puter halts. If the operator presses the START button, the 
program will continue by going to the (y) address for its 
next instruction. If the address given in (y) is the same 
as that given for the HALT instruction, the computer will 
simply do another program stop. 



REVIEW AND EXPLANATION OF THE NINE INSTRUCTIONS COVERED ; 

CLA - used to move data into the AC prior to an operation 
(i.e. add) 

ADD - used to add the c(y) address to the c(AC), 

SUB - used to subtract the c(y) address from the c(AC), 

MPY - used to multiply, but first the multiplicajid must be 
placed into the MQ. This is done with the LDQ in- 
struction. 

DVH - used to divide, but first the dividend must be placed 
into the AC-MQ. This is also done with the LDQ in- 
stmction. If we wish to move the quotient back to a 
storage address, the STQ instiniction is used. 

STO - used to move the c(AC) to a storage address. This 
would be used after add or subtract - or if the re- 
mainder of a division problem is to be saved. Also 
if data is to be moved from one storage location to 
another, 

HTR - used to stop the program. 

Another way to remember this is; 

CLA moves data into the AC from storage, 
STO moves data into storage from the AC. 
LDQ moves data into the MQ from storage. 
STQ moves data into storage from the MQ. 

The other five instructions are; add, subtract, multiply, 
divide and halt. These are self explanatory. 



Y 


_.► 


AC 


AC 


-» 


Y 


Y 


-^ 


MQ 


MQ 


-^ 


Y 
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Lesson 3» (cont'd) 

EXAMPLES PROGRAM 

1. ADD Step 1. CLA A 
A + B 2. ADD B 

and place sum 3. STO 50 
into storage k, HTR 
at pos. 50 



REMARKS 

Move A into the AC 
Add B to A 



Store 
Halt 



'sum" into loo. 50 



Place the 1. CLA A Move A into AC 

diff. of A-B 2. SUB B Subtract B from A 

into storage 3. STO 150 Store "difference" into 150 

loc. 150 k. HTR Halt 



3, Place the 
prod, of AxB 
into loc. 520 

4, Place the 
quotient of 
AtB into loc. 
600. Place 
"remainder 



1. LDQ A Move A into the MQ 

2. MPY B Multiply AxB 

3. STO 520 Store "product" into 520 
k. HTR Halt 

1. CLA Place zeros in AC prior to Div. 

2. LDQ A Move dividend into AC-MQ 

3. DVH B Divide A f B 

k, STQ 600 Store "quotient" into 6OO 

5. STO 20 Store "remainder" into 20 



into loc. 20 6. HTR 



Halt 



Note: When the dividend is placed in the MQ (Step 2), the 
sign of the AC should be made to agree with the sign of the 
MQ to assure that algebraic division will take place if the 
dividend is negative. This means that a Long Left Shift of 
zero should be placed between Steps 2 and 3» This has been 
omitted here and in pages 3k, 36 and 38. Since the Long 
Left Shift instruction has not yet been studied, it will be 
presumed that the dividends are positive numbers. 

INSTRUCTION: TZE (Transfer on Zero) Octal code: +0100 
FORMAT ; [Type B) 



OPCODE 



TAG 



S.I 1112-13 18-2021 35 

Description : If the c(AC) is zero, the next instmiction is 
taken from the location specified by (y) . If the c(ac) is 
not zero, program will take the next instruction in sequence. 

INSTRUCTION ; TOY (Transfer on Overflow) Octal code: +0l40 
FORMAT ; (Type B) 



OP CODE 


lA 


■ "» 


Y 



SJ 1112-13 18-2021 35 

Description : In addition and subtraction, if an overflow oc- 
curs, the AC overflow indicator is turned on. This instmic- 
tion tests the indicator. If it is "on", it is turned "off 
and the next instruction is taken from the location speci- 
fied by (y) . If the indicator is "off", the program will 
take the next instruction in sequence. 

Do not continue beyond page 36 until the use of these in- 
structions is completely clear to you. If necessary, go 
back to page 27 and read through the lesson again. 
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Lesson 3» (cont'd) 

FORMAT FOR WRITING A PROGRAM ; In the problems and examples 
to follow, coding will be accomplished under the following 
headings : 



LOG 



op 



ADDRESS 



REMARKS 



LOG - refers to the storage location of the instroiction 
or data. Instead of referring to "steps", we will 
assign storage locations to each instruction step. 

OP - refers to the operation code. 

ADDRESS - refers to the location containing the information 
or instruction with which the operation is con- 
cerned, 

REMARKS - refers to a brief explanatory note of what is 

being accomplished. This is a very handy device 
for the progreimmer to use as it gives him a clear 
picture of what he is doing at all times, 

EXAMPLES : 



1. 



2. 



Start the program 
in loc. 100 and 
the "if zero" part 
of the program in 
loc. ^00, A is in 
loc, 50 and B is 
in loc, 60, 



Place the sum of 
A + B into loc. 
200. If sum is 
zero, also place 
the sum into loc. 
210. 



Start program in 
loc. 100, A is 
in loc, 50 » B is 
in loc. 60, 



Place the dif- 
ference of A-B 
into loc, 200, 
If overflow oc- 
curs, go to loc, 
150, place A in- 
to loc. 400 and 
B into loc. 450, 
then stop the 
prog. 









PROGRAM 


LOG 


OP 


ADDRESS 


REMARKS 


100 


CLA 


50 


Move A into AC 


101 


ADD 


60 


Add A + B 


102 


STO 


200 


Sum into 200 


103 


TZE 


4 00 


If zero , progreun 
jumps to loc. 400 
for next instruc- 
tion. 


104 


HTR 


104 


If not zero, halt 
(loc. address re- 
peated to force 
halt) 


400 


STO 


210 


Sum into 210 


401 


HTR 


401 


Halt 


LOC 


OP 


ADDRESS 


REMARKS 


100 


CLA 


50 


Move A into AC 


101 


SUB 


60 


Subtract B from A 


102 


TOV 


150 


Test for over- 
flow. If "yes", 
go to loc. 150 
for next instr. 


103 


STO 


200 


If no overflow, 
store difference 
in 200 


104 


HTR 


104 


Halt 


150 


CLA 


50 


Move A into AC 


151 


STO 


400 


Store into loc. 
400 


152 


CLA 


60 


Move B into AC 


153 


STO 


450 


Store into 450 


154 


HTR 


154 


Halt 
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Lesson 3» (cont'd) 



VORK AREA 



PROBLEMS ; 



B 



For all problems, use storage locations! 



50 




60 




70 




80 



Start all programs in location 100 and any jumps in loca- 
tion 200. 

kk. Place the sum of A + B into location 400. If the sum 
is zero, also place A - B into location 300. 



LOG 



OP 



ADDRESS 



REMARKS 



45, Place the sum of A + B + C into location U25. 

LOG OP ADDRESS REMARKS 



46, Place the product of B x C into location 350, 

LOG OP ADDRESS REMARKS 



47, Place the quotient of A -^- D into location 325, Place 
the remainder into location 326, 



LOG 



OP 



ADDRESS 



REMARKS 
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Lesson 3, (cont'd) 



PROBLEMS : 



CORRECT ANSWERS 



hk. 



LOG OP 



ADDRESS 



REMARKS 



100 CLA 50 

101 ADD 60 

102 STO 400 

103 TZE 200 

lO^t HTR 104 

200 CLA 50 

201 SUB 60 

202 STO 300 

203 HTR 203 



Move A into AC 

Add B to A 

Place "sum" into 400 

If sum is zero, jump to 200 for 

next instr. 

If not zero, halt. 

Move A into AC again 
Subtract B from A 
Place into 300 
Halt 



45. 



LOC OP 



ADDRESS 



REMARKS 



46. 



100 


CLA 


50 


Move A into AC 


101 


ADD 


60 


Add B to A 


102 


ADD 


70 


Add C to sum of B and A 


103 


STO 


425 


Place sum into loc. 425 


104 


HTR 


104 


Halt 


LOC 


OP 


ADDRESS 


REMARKS 



100 LDQ 60 

101 MPY 70 

102 STO 350 

103 HTR 103 



Move B into MQ 
Multiply by C 
Place into loc. 350 
Halt 



47. 



LOC OP 



ADDRESS 



100 CLA 

101 LDQ 50 

102 DVH 80 

103 STQ 325 

104 STO 326 

105 HTR 105 



REMARKS 



Place zeros into AC 

Move A into MQ 

Divide by D 

Place quotient into loc. 325 

Place remainder into loc. 326 

Halt 
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Lesson 3» (cont'd) 

VORK AREA 
PROBLEM: Use the same general instructions as on page 33. 

48, Compute: A B 

C - D if an overflow occurs, place the 
number 5 (presently in loc. 90) into location 325 and halt. 
Otherwise, continue the problem and place the quotient into 
location 4oO and the remainder into location 401 (See note 
below) . 

LOC OP ADDRESS REMARKS 

100 



NOTE: All arithmetic operations take place in the AC and 
MQ. If several different operations must be accom- 
plished and the results need to be saved for a later 
operation, the results are moved to temporary storage 
locations and recalled from there when needed. 

In the above problem, the result of A x B and the 
result of C - D must both be saved so that the final 
division may be accomplished. It makes no difference 
where they are placed in storage as long as those 
storage locations are not being used for anything 
else. 
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Lesson 3i (cont'd) 



CORRECT ANSWERS 



When a problem begins to be complicated, it should be flow 
charted before it is coded. A flow chart of this problem 
would look like this: 




START 



MULTIPLY 
A X B 



PRODUCT 
INTO TEMP h* 
STORAGE 



PROBLEM ; 
^8. LOC 



OP 



ADDRESS 



100 
101 
102 

103 
104 
105 

106 



107 
108 



109 

110 
111 
112 

200 
201 
202 



LDQ 
MPY 
STO 

CLA 
SUB 
STO 

TOV 



CLA 
LDQ 



DYH 

STQ 
STO 
HTR 

CLA 
STO 

HTR 



50 
60 
600 

70 
80 
650 

200 




600 



650 

400 
401 
112 

90 

325 

202 



SUBTRACT 
C-D 




DIFFERENCE 

INTO TEMP 

STORAGE 








yK 






/ I LSI \^ 

/DIFFERENCE 
\ FOR 
\ OVER- y 


SYES 


PLACE NO. 

5 INTO 
LOC. 325 




NFLOW/ 

JNO 










DIVIDE PROD 

OF A X B BY 

DIFFERENCE 

OF C-D 






(^HALTZ; 








1 






QUOTIENT 
INT0400 
REMAINDER 








r HALTI j 








INTO 401 







REMARKS 



Move A into MQ 
Multiply by B 

Place product into temporary 
loc. 600 
Move C into AC 
Subtract D from C 
Place difference into tempo- 
rary loc. 650 

Test for overflow. If "yes" 
jump to loc, 200 for next 
instruction 
Move zeros into AC 
If no overflow, move result 
of mult, into MQ so that 
division may be accomplished. 
Divide by result of subtrac- 
tion. 

Place quotient into loc. 400 
Place remainder into loc. 401 
Halt - end of job 

Move "5" into AC 
Place into loc. 325 
Halt 2 - end of job 
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Lesson 3» (cont'd) 



BINARY POINT ; It was pointed out on page 27, that the 
Binary Point must be determined by the programmer when work- 
ing with Fixed Point numbers. A few examples may clarify 
this further. Fraction conversion may be accomplished by 
referring to Appendix C, IBM 709O Reference Manual. 



EXAMPLES ! 
1. Add; 



^5 -210 
3.27^ 






Result : 



10 



187574 



10 



+ I 
= 22.363 



■♦ I 00 I 00 I 
— I — I — I — I — I I I — l__l 



21 



I 10 1 I 
I — I — I — I — I — I 



35 



8 



2, Multiply ; 



^ I^ 



6 



BINARY POINT 



a. Assign the first Octal integer (whole ntunber) as a 
flag (converting to Binary) 



EXAMPLE ; 



2.7 



8 



HO I 01 II 

I I I ■ • 



b. 
c. 



Binary point between posi- 
tions 3 and k. Flag is 3 
(we will call it B 3 - the B 
representing Binary and also 
indicating fixed point 
numbers ) 



Set up a flag for both multiplicand and multiplier. 



After multiplication, consider the AC and MQ as one 
long 70 bit register (no count is taken of the S, Q, 
P in the AC, or the S in the MQ) . The position of 
the Binary Point will be the sum of the two flags. 




Q 

S 



AC 



MQ 



Q P I 
EXAMPLE ; 

EXAMPLES ) 



70 



35 363738 

B 3 and B 35 = B 38— -^^( this is the location of 

the B.P. in product.) 



1. 



D 

s 



Multiply a B6 number and a B30 number. Show the loca- 
tion of the Binary Point in the AC - MQ, 

B6 + B30 = B36 







AC 


S 


MQ 








' 1 1 



QP I 



35 



3637 



70 



-Binary Point 



2. Multiply 32.6573 by 3.44444g. Show the location of the 
Binary Point of the product in the AC - MQ. 

Step 1 ; 32,657 (two Octal integers before the fraction) 

Flag = B 6 
3.44444 (one Octal integer before the fraction) 

Flag = B 3 
Step 2 ; B6 + B3 = B9r-| AC r— l MQ 



1 



35 36 
Binary Point 



70 



37 



Lesson 3i (cont'd) 

3, Division ; Assign flags for both the divisor and the 

dividend, as in multiply operations. However, when the 
dividend is brought into the AC-MQ, consider both AC 
and MQ as a 70 bit register with the flag located in the 
proper position of the 70» 

The dividend is 16.5- 



EXAMPLE 



'8 



The first step is to clear the AC (CLA o) 

The second step is to load the dividend into AC-MQ (ldQ X) 












AC 










MQ 










n ^ 




^ n 


00 1 

I 1 1 


10 10 
■ 1 1 1 1 








0.-* 







I 35 36373839405I42«44 70 

Binary point = B4l (flag) 

The quotient will be in the MQ and the remainder in the AC, 
so after divide has been accomplished, the MQ must again be 
considered as a 35 bit register* 

If we divide by a B27 number, *the quotient in the MQ will be 
4l-27=Bl^ 

•- 1 

1 1 1 I— I I U.J — I 1 1 1 1 1 L-J. 

If the divisor happens to be quite small, it is 



EXAMPLE 2 ; 

possible to lose a portion of the quotient. 

Divide 27^.5553 by 15.321g 

Step 1 ; Dividend 27^.5558 = B9 (3 Octal = 9 Binary) 
Step 2 ; Move to MQ = Bkk (35 in AC + 9 in MQ = kh) 
Step 3 ; Divide by a B6 number (15.3213 = B6 2 Octal = 



6 Binary) 
Step h : Bkh - B6 = B38 



MQ 



35 



1 

-I I- J 

38^ 



The three trailing positions would be lost 

In these examples and in the problems that follow, all 
numbers are assumed to be left adjusted. This means that 
the digits are located in the extreme left part of the word 
in storage. 



D 



WORD IN STORAGE 



xxxxxxxxx 

I I I 1 ' ■ I 1 (_ 



BINARY POINT 



35 



38 



Lesson 3» (cont'd) 



¥ORK AREA 

PROBLEMS ; (All hypothetical niimbers will be considered to 
be in Octal, left adjusted and all dividends 
loaded into the MQ) 



Multiply and show location 

of Binary point of the product 

in AC - MQ. 

49. XXX. X by XX. XXX 
Pr oduc t : B 

50. .XXXXX by .XXXX 
Product: B 

51. X. XXXXX by X.XXXX 
Product: B 

52. XXXX. by XXXX. 
Product: B 

53. XXXXXXXXXX.X by XXX. X 

Product : B 

5^. XXXXXXXXXXXX.XXX by 

XXXX. XXX 
Product: B 

55. .XXX by X.XXX 

Product: B 



Divide and show location of 
Binary point of the quotient 
in the MQ. 



56, X.XX I XXX. XX 



Quotient: B 



57. .xxxxxxx I XXXXX. XXX 



Quotient; 



58. XXXXXXXX.X XXXXX. XXXX 



Quotient: B 
59. .XX I XXX. XX 
Quotient: B 



60. XXXXXXXXXXX I XX. XX 



Quotient! 



B 



61. .X I .X 



Quotient: B 



62. XX. X XX. XX 



Quotient: B 
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Lesson 3, (cont'd) 



CORRECT ANSWERS 



PROBLEMS ; 

49. B9 + b6 = B15 



50. BO + BO = BO 



51. B3 + B3 = B6 



52. B12 + B12 = B2it 



53. B30 + B9 = B39 



54. B36 + B12 = Bh8 



55. BO + B3 = B3 



56. B3 B9 



D 



B35 + B9 = Bhk (after 
move into MQ) 

B44 - B3 = B41 

MQ 



35 



41. 



57. B21 BI5 



58. 



B35 + BI5 = B50 

(dividend) 

B50 - B21 = B29 (in MQ) 

B2U [ BI5 

B35 + B15 = B50 

B50 - B24 = B26 



Problems 6I and 62 show that 
whenever the dividend and 
divisor have the same "B" 
number, the Binary Point will 
be at B35 in the MQ, 



q 



MQ 



35 



59. 



BO I B9 

B35 + B9 = Bkk 

Bijit - BO = B^if (9 
trailing positions 
would be lost) 



60. 



61. 



62. 



B33 


J B6 




B35 


+ b6 = 


bUi 


b4i 


- B33 = 


= B8 


BO 


BO 
+ BO = 




B35 


B35 


B35 


- BO = 


B35 


B6 


B6 
+ B6 = 




B35 


b4i 


b4i 


- B6 = 


B35 



ko 



LESSON 4 

FLOATING POINT NUMBERS ; If the range of numbers in a calcu- 
lation is apt to be quite large or unpredictable, fixed 
point numbers no longer serve the purpose because it be- 
comes impossible to calculate the position of the Binary 
Point . An alternative set of Floating Point instructions 
are available and should be used for such calculations. 
¥ith these instructions, the Binary Point is automatically 
maintained between the 8th and 9th digit of the word . A 
Floating Point number is stored in a word as shown below: 







(— BINARY POINT 



" 



CHARACTER 
(EXPONENT) 



FRACTION (MANTISSA) 



J 



89 35 



The fraction (also called the Mantissa) is always stored in 
positions 9-35 and the characteristic (exponent) is in posi- 
tions 1-8. This portion must be explained in more detail: 
A floating point ntunber may be expressed as a signed 
proper fraction multiplied by some power of 10. The number 
is normal (or normalized) if the power is chosen in such a 
way that the decimal point is to the left of the most sig- 
nificant digit, 
EXAMPLES ; 

.350^Q = .35 X 10^ Note that the powers of 1, 2, 
3.50j^Q = .35 X 10^ and 3 are in direct ratio to 
35.0j^Q = .35 X 10„ the number of places the deci- 
350. ^Q = .35 X 10 mal point is moved to the left. 



• 035-|^Q = .35 X 10 If the decimal point is moved 

•0035 = 35 X 10~^ *° *^® right, it works in the 
10 * same way except, that the 

power is then negative. 

A floating point Binary number may be expressed in the 
same manner as the Decimal numbers above except that it will 
be multiplied by some power of 2. 
EXAMPLES: 

.001 = ,100 X 2„ (Binary point moved two 
100.000 = .100 X 2^ positions to right) 
(Binary point moved three positions to left) 

If the ntunber is normal , bit position 9 will ali^ays be a 1. 
If it is not normal , bit position 9 will always be a zero. 

The characteristic is formed by adding +128 to the ex - 
ponent (the exponent being the number of the power ) . Con- 
verting to Octal: +128 = +200. 

EXAMPLE ; ^ ^ ,^, ,^, 3 
5.-LQ = 5.g = 101.2 ■'■°-'-* - •■'■^^ ^ ^ •^^'^ ^°° *^ 

to go into the characteristic . The fraction goes 
into the Mantissa portion of the word. 

Since there are only eight positions in the character - 
istic , the leftmost Binary position is dropped. If an over- 
flow occurs , it may be checked by the program. 
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Lesson 4, (cont'd) 

ADDITIONAL EXAMPLES ; 

1. Show normalized, floating point 10^^ as it would look in 

a machine word. 

Step 1: Chg from Dec to Oct to Bin Final Step: Move result 

of Step 3 into Charact. 
Move result of Step 2 
k into Mantissa 



Step 2: Move Binary point 

001 010. = .1010 X 2 



I 0000 i 00 10 1 



35 



Step 3: Add Exp to Oct 200 

200 + 4 = 20U +1 o' "4 

Note that although the Octal number was 12q, in the Mantissa, 
it now looks like a 5. The programmer must be aware of 
this apparent change. 



2. Show normalized floating point ,0039jlq as it would look 
in a m£Lchine word. 

Step 1: .0039,-. = .002j, = .000 000 010 When the exponent 

1" ° _7 "^ will be a minus, the 
Step 2: .000 000 010 = . 10 x 2 ^^^^^ gOO and the 

Step 3: 200j, - 7q = 128 - 7,o = ^21,^ exponent must be 

8 8 lO iu xu ^jonverted to Deci- 

= -^71g mai , then converted 

Step k: Step 3 into Charact. Step 2 back to Octal. 

into Mantissa 







01 I I I 001 



100' 
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3. Show normalized floating point kk^^ as it would look in 
a machine word. 



Step 1: 4^. 10 = 5^*8 = ^^^ ^^^' 
Step 2: 101 100. = .101100 x 2 

Step 3: 200 + 6 = 206g 



Final Step: 
6 Is. I 00001 I Oil 01 10- 



3 



+ 2 
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k. Show normalized floating point -20^^^ as it would look in 
a machine word. 



Step 1? -20, ^Q = -24. g = -010 100.2 



Final Step: 



^ 



OOOOIOI 



101 0- 



-♦0 



+ 2 



Step 2: -010 100. = -.10100 x 2 
Step 3: 200 + 5 = 205g 

Warning ; Be sure to remember that the Characteristic is 
always derived in Octal. Very bad mistakes can be made if 
the exponent is not converted to Octal before adding to 
200g. 



35 
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Lesson k, (cont'd) 



¥ORK AREA 



PROBLEMS ; 



63. Show normalized floating point 3-,^^ as it would look in 
a machine word. 



Step 1: 



Step 3! 



Step 2: 



Final Step: 



D 



6k. Show normalized floating point ,003,^ as it would look 
in a machine word. 



Step li 



Step 3: 



Step 2; 



Final Step: 



D 



-i — I — 1 — I — I i_ 



65. Show normalized floating point 232^^ as it would look 
in a machine word. 



Step 1: 



Step 3! 



Step 2, 



Final Step: 



D- 



-J — I — 1 — 1 1- 



h3 



Lesson k, (cont'd) 



CORRECT ANSWERS 



PROBLEMS : 



63. 



Step 1: 3-LQ = 3g = 011'2 
Step 2: Oil, = .11 x 2 



Step 3: 200 + 2 = 202g 
Final Step: 







I 00000 I 



I 10-*- 



6k. 



+ 2 2 



Step 1: •003-|_Q = .00306g = .000 000 Oil 000 llOg 

-7 
Step 2: = .1100011 x 2 

Step 3: 200g - 7g = 128^^ - T^^ = 121^^ = ^"^Ig 
Final Step 







ON I I 001 



I I 0001 I o-*- 



+ I 7 1 



65. 

step 1: 232j^Q = 350g = Oil 101 000, ^ 

Step 2: = ,11101 x 2 (8 not permitted in Octal 

jumps to 10 after 7) 



- always 



Step 3: 200 + 10 = 210 



8 



Final Step: 







I 0001 000 



II 10 10' 



+ 2 I 



The material covered on page kl may be entirely new to the 
student, even to the terms "power", "exponent" , "normalized", 
etc. If it is new, please go over it a second time and 
make up some additional problems to get extra practice in 
this area. Use the Octal/Decimal conversion tables (Ap- 
pendix B and c) in the 7090 Reference Manual to speed up 
the conversion of both integers (whole numbers) and 
fractions. 
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Lesson 4, (cont'd) 

FLOATING POINT ARITHMETIC : The location of the decimal 
point, or Binary point, is an extremely importeint problem 
in programming. Just as in "pencil-and-paper" arithmetic, 
decimal points must be lined up and additional zeros must 
be added where required. 

EXAMPLE ; Add + 100.0 and - 0.1002. If they were not lined 
up, they would look like this: 

+ 100.0 
- 0.1002 

To line them up, the lower number must be shifted to the 
right two places and three trailing zeros must be added to 
the upper number: 



+ 100.0 1000 



0.1 002 

The same numbers in floating point (Decimal) form, nonnal- 
ized, would look like this: 

+ .1000 X IOq 
- .1002 X 10 

To equalize the exponent , the lower number is again 
shifted to the right and trailing zeros are added to the 
upper number, as follows: 



+ . 1000 lOOOl X 10^ 
- . fOOOl l 002 X 10-^ 

If the result is not normal « it must be shifted right to 
finish with a normalized number: 

+.1000000 X 10^ 
-.0001002 X lO-' 



.0998998 X 10^ = .998998 x 10^ 



Since the progreunmer does not usually work with actual 
numbers, but with quantities where only the maximum and 
minimvun size is known, the problem becomes much greater. 
This text must, of necessity, be limited to fundsunentals 
of 7090 programming, therefore this will not be covered in 
detail here. 
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Lesson k, (cont'd) 

FLOATING POINT OPEItATIONS ; 

INSTRUCTION ; FAD (Floating ADD) Octal code: +O3OO 

FORMAT ; (Type B) 



OP CODE |lA 'fy^y^y TAG Y 



S,l 1112-13 18-2021 35 

Description ; The floating point number in Y is added alge- 
braically to the floating point number in the AC. The most 
significant part of the number is in the AC as a normalized 
floating point number and the least significant part is in 
the MQ as a floating point number with a characteristic 33 
less than the AC characteristic . The sign in both the AC 
and MQ will be that of the larger factor. 

INSTRUCTION ; FSB (Floating Subtract) Octal code; +0302 
FORMAT: (Type B) 



OPCODE 


lA 


'//M 


TAG 


Y 



S,l 



1112-13 



18- 2021 



35 



Description : The floating point number in Y is subtracted 
algebraically from the floating point number in the AC. 
The result is always notTnalized and located in the AC, 

INSTRUCTION: FMP (Floating Multiply) Octal code: +O26O 
FORMAT: (Type B) 



OPCODE 



lA 



^ 



TAG 



S,l 



112-13 



18-2021 



35 



Description : The floating point number in Y is multiplied 
algebraically by the floating point number in the MQ. The 
most significant part of the product will be in the AC and 
the least significant part in the MQ. If either of the 
numbers is not normalized, the product may or may not be in 
normalized form. 

INSTRUCTION ; FDH (Floating Divide or Halt) Octal code: 
FORMAT: (Type B) 



OPCODE Ik ////// IkQ, Y 



S,l 



1112-13 



18-20 21 



35 



Description ; The c(ac) are divided algebraically by the 
c(y) . The quotient will be in the MQ and the remainder will 
be in the AC. If the size of the fractional part of the AG 
is equal to or greater than twice the fractional part of the 
number in Y (this would only happen in unnormalized num- 
bers), or if the number in Y is zero, the Divide Check 
Indicator turns on and the computer stops. The quotient 
will be in normalized form if both the dividend and 
divisor were normalized. 



46 



Lesson 4, (cont'd) 

INSTRUCTION ; ALS (Accumulator Left Shift) Octal code: +O767 
FORMAT ; [Type B) 



OPCODE lA 



TAG 



S.I 



1112-13 



18-2021 



35 



Description ; The c(AC) are shifted to the left the number 
of places specified in positions 28-35 of the address por- 
tion of the instruction. Vacated positions are automati- 
cally filled with zeros. If the instruction calls for a 
shift larger than the bit capacity of the AC, it will be 
completely filled with zeros, 

INSTRUCTION; ARS (Accumulator Right Shift) Octal code:+0071 
FORMAT ; (Type B) 



OPCODE 



TAG 



S,l 



1112-13 



18-2021 



35 



Description ; Identical to the ALS instruction except that 
the shift is to the right, 

INSTRUCTION: TPL (Transfer on Plus) Octal code: +0120 
FORMAT ; [Type B) 



OP CODE 



LA 



TAG 



S,l 



1112-13 



18-2021 



35 



Description ; If the sign position of the AC is positive 
(Binary zero) , the computer takes its next instnaction from 
location Y, If the sign is negative (Binary one) , the com- 
puter goes to the next instruction in sequence. 

INSTRUCTION: TMI (Transfer on Minus) Octal code; -0120 
FORMAT : (Type B) 



OP CODE 


lA 


WM 


TAG 


Y 



S,l 



1112-13 



18-2021 



35 



Description : If the sign position of the AC is negative 
(Binary one) , the computer takes its next instruction from 
location Y. If it is positive (Binary zero), the computer 
goes to the next instruction in sequence, 

INSTRUCTION : XCA (Exchemge AC and MQ) Octal code: +OI3I 
FORMAT ; (Type D) 

v/Mi/m/mm/m 



OP CODE 



S,l 



II 



Description ; The c(AC) and the c(MQ) are exchanged. Posi- 
tions P and Q in the AC are cleared to zeros. 
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Lesson 4, (cont'd) 

EXAMPLES ; Use storage locations as follows 

A B C D 



50 60 70 80 



Start program in location 100 and any jumps in location 200. 

1. AB + CD = T (floating point niimbers) Place T into loca- 
tion 400. If T is positive, compute A-B and place the dif- 
ference into location 450. 



LOG OP ADDRESS REMARKS 



Move A into MQ 

Multiply A X B 

Product stored in temporary loc. 

Move C into MQ 

Multiply C X D 

Add product of AB to product of CD 

Place sum (t) into location 400 

If T is +, go to loc, 200 next 

instr. 

If T not +, end of progreiin 



200 CLA 50 Move A into AC 

201 FSB 60 Subtract B from A 

202 STO 450 Place difference into loc. 450 

203 HTR 203 Halt 2 - end of program 



100 


LDQ 


50 


101 


FMP 


60 


102 


STO 


300 


103 


LDQ 


70 


104 


FMP 


80 


105 


FAD 


300 


106 


STO 


400 


107 


TPL 


200 


108 


HTR 


108 







2. A = P (floating point numbers) If P is negative, place 
D 

into location 400. If not negative, place into location 450 
and do not place into location 400, 

LOC OP ADDRESS REMARKS 

Move A into MQ 

Divide by D 

If sign of quotient is -, go to 

loc. 200 next instruction 

If sign not -, store quotient into 

location 450 

Halt - end of job 



Store quotient into loc. 400 
Halt 2 - end of job 



100 


LDQ 


50 


101 


FDH 


80 


102 


TMI 


200 


103 


STQ 


450 


104 


HTR 


104 


200 


STQ 


400 


201 


HTR 


201 
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Lesson 4, (cont'd) 
EXAMPLES Continued ; 

3. A - B = V (floating point) Place ¥ into location 900. 
LOG OP ADDRESS REMARKS 

100 CLA 50 Move A into AC 

101 FSB 60 Subtract B from A 

102 STO 900 store difference into loc. 

900 

103 HTR 103 Halt - end of job 



PROBLEM; (Storage locations the same as for examples on 
page 48) 
(Also, X in location 90) 

p 

66, A_+_BX + X = T (floating point) Place T into location 
^ 500. 

Flow chart the problem before attempting to code it. 

LOC OP ADDRESS REMARKS 

100 



h9 



Lesson h, (cont'd) 



CORRECT ANSWER 



PROBLEM ; 
66, 



START 




MULTIPLY 

X BY 

ITSELF 



STORE IN 

TEMPORARY 

LOCATION 



(X2) 



MULTIPLY 
BxX 


-* 


ADD A 
TO PRODUCT 


- 


DIVIDE 
BYC 


(BX) 




(A+BX) 




A+BX 



EXCHANGE 
AC ANDMQ 



ADD X'=^ 

FROM TEMP 

LOCATION 



(TO MOVE . A+BX 2) 

QUOT.INTOAC) C 



RESULT 

INTO LOG. 

500 




HALT 
ENO-OF-JOB 



) 



LOG 



OP 



ADDRESS 



REMARKS 



100 


LDQ 


90 


101 


FMP 


90 


102 


STO 


300 


103 


LDQ 


60 


104 


FMP 


90 


105 


FAD 


50 


106 


FDH 


70 


107 


XCA 




108 


FAD 


300 


109 


STO 


500 



110 



HTR 



110 



Move X into MQ g 

Multiply X by X tb get X 

Store result in temporary loc. 

Move B into MQ 

Multiply B by X 

Add A to product 

Divide by C 

To move quotient from MQ to 

AC 2 

Add X to previous total 

Store final result into loc. 

500 

Halt - end of job 



If the XCA instruction had not been used (loc. 107), it 
would have taken two instructions to move the quotient from 
the MQ into the AC, so that addition could be accomplished. 
The alternative would have been to move the quotient from 
the MQ into storage and back from storage into the AC, Use 
of the XCA simplifies this for us. 
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Lesson 4, (cont'd) 

OVERFLOW AND UNDERFLOV : The "characteristic" contains eight 
bit positions. If all eight were filled with ones, the re- 



sultant number would be 377q = 255,^. 

o 10 



We add +128 to the 



exponent to derive the characteristic, therefore any- 
characteristic larger than +177q (+127 ) would cause an 
overflow (the result is too large for storage to contain). 
Also, auiy characteristic below -200o (-128 ) would cause 
an iinderflow. 



The maximum and minimum characteristic capability- of the 
machine is +127, q and -128 q. If these figures are ex- 
ceeded, the computer will put the address plus one of the 
instruction causing the trouble into the address portion of 
location 0000. An identifying code which tells whether an 
overflow or underflow occurred and whether the most signi- 
ficant result is in the AC or MQ, is placed in the Decrement 
portion of location 0000. The computer continues by exe- 
cuting the instruction at OOlOg, and continuing on from 
there. This is called a floating point trap and the over- 
flows and underflows are called spills . 

The spill codes are as follows: 



Operation 



AC 



MQ 



Decrement 



Add, Subi 


;rac 


t 




underflow 











1 


Multiply 






underflow 


underflow 








1 


1 


Round 
Round 






overflow 
overflow 


overflow 






1 
1 


1 
1 




1 



Divide 
Divide 
Divide 
Divide 



underflow 
underflow 



tinderflow 10 1 

10 10 

underflow 10 11 

overflow 110 1 



These codes are used to aid the programmer in checking for 
overflow and underflow conditions. The programmer places a 
transfer instruction in location OOlOg, transferring the 
program to a routine which is designed to take care of the 
overflow or underflow condition. Every programming group 
has such a routine developed emd ready for use with most 
programs , 
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Lesson 4, (cont'd) 

INSTRUCTION ; NZT (Storage Not Zero Test) Octal code: -0520 

FORMAT; (Type B) 



OPCODE 


lA 


''/m 


TAG 


Y 



S.I 



III2H3 



18-2021 



35 



Description ; If the contents of Y are not zero, the com- 
puter skips one instruction. If the c(y) are zero, the 
computer tsikes the next instruction in sequence. The c(y) 
remain unchanged. 



EXAMPLE ; (Use storage locations as in the earlier examples) 

If location 'lOO contains zeros, place the sum of floating 
point A + B into it. If it does not contain zeros, place 
the sum of A + B into location 600. Show a partial program 
to accomplish this action. 



LOG 



OP 



ADDRESS 



REMARKS 



100 


OLA 


50 


101 


FAD 


60 


102 


NZT 


Uoo 


103 


TRA 


200 



104 



105 



STO 



HTR 



600 



105 



Move A into AC 

Add B to A 

Test Loc. hOtO for zeros 

If zeros in '^OO, trans, to 

location 200 

Store sum in 600 (since the 

test showed no zeros - or 

the program would never get 

this instruction) 

Halt - end of job 



200 
201 



STO 
HTR 



40C 
201 



Store sum into 400 
Halt 2 - end of job 
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Lesson 4, (cont'd) 

INSTRUCTION ; ZET (Storage Zero Test) Octal Code: +0520 

FORMAT ; (Type B) 



OP CODE 


lA 


W///, 


TAG 


Y 



S.l 



1112-13 



18-2021 



35 



Description ; If the contents of Y are zero, the computer 
skips one instmiction. If the c(y) dre not zero, the com- 
puter takes the next instruction in sequence. The c(y) 
remain unchanged. This is exactly the reverse of the NZT 
instruction. 



EXAMPLE ! 



(Use storage locations as in earlier examples) 



If location 400 contains zeros, place the sum of floating 
point A + B into it. If it does not contain zeros, place 
the sum of A + B into location 600. Show a partial program 
to accomplish this action, (Note; This is the same problem 
as the one on page 52, but notice the difference in the 
program when the ZET instruction is used). 



LOC 



OP 



ADDRESS 



100 CLA 50 

101 FAD 60 

102 ZET 400 

103 TRA 200 



lOi* 



STO 



400 



105 



HTR 



105 



REMARKS 



Move A into AC 
Add B to A 

Test loc, 400 for zeros 
If not zero in 400, trans- 
fer to 200 

Store sum into 400 (since 
test must have showed 
zeros - or the program 
would not have reached this 
instr. * 
Halt - end of job 



200 
201 



STO 
HTR 



600 
201 



Store sum into 600 
Halt 2 - end of job 
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Lesson k, (cont'd) 

MOST SIGNIFICANT AND LEAST SIGNIFICANT ; In Floating Add and 
Floating Multiply, the statement was made that the most sig- 
nificant part of the result would be in the AC and the least 
significant part in the MQ. 

Under normal circumstances, the sum and/or the product may- 
be considered to be in the AC and the STO (store) instruc- 
tion is used to move the data back into memory. 

Occasionally this will cause trouble for the following 
reason; in a floating point number, the first eight posi- 
tions of the word are taken up by the Characteristic, This 
leaves 27 positions (or 9 Octal digits) for the sum or 
product. If the numbers to be added or multiplied are large 
enough to result in a sum or product larger than 9 Octal 
digits, the least significant portion will be in the MQ and 
will be lost if the data is moved back into storage with a 
STORE instruction, 

EXAMPLE ; Add (Octal) 1000000000. 

+ 1.0012 



SUM; 1000000001.00120000 



This will be in i 
AC since only J 
9 Octal will fit 
into frac. 



This will be in 
MQ, also in the 
fraction part 
(posit. 9-35) 



In this case, if only the STO instruction were used, a very 
important part of the number would be lost. The STQ must 
also be used and the total sum stored in two words since it 
is too large to fit into one word. 

Unless the progreimmer knows that this is an important 
factor in a particular program, he may forget about the 
least significant portion, but if it is importetnt to save 
fractions to the very last point, then he must arrange in 
the program to protect the result of FAD smd FMP. 
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LESSON 5 

SYMBOLIC CODING ; Ve have been using symbolic operation 
codes because they are simpler and more easy to remember 
than either Binary or Octal (ADD is more easily remembered 
than +04008 or the Binary form: 000 100 000 OOO) , Sjnnblic 
coding may also be used in the other parts of an instruction 
(address, tag, decrement). 

In a large program, keeping track of actual addresses can 
become extremely difficult emd error prone. If the pro- 
graimner wajxted to add A + B, it would be much simpler to 
write: CLA A; ADD B, than to assign specific storage lo- 
cations to each symbol. 

¥hen writing programs in "symbolic," every symbol used in 
the program must be defined by the programmer, preferably 
at the end of the program. This is most easily explained 
with an example : 

EXAMPLE: Add A + B. Store sum in HOLD. 

LOC OP ADDRESS REMARKS 

Move "A" into AC 

Add A + E 

Sum to loc. HOLD 

END HTR END Halt (since actual loca- 
tions are no longer used, 
placing the same symbol 
(end) in both LOC and AD- 
DRESS, accomplishes the 
purpose of permanently 
halting the prbgram. 

A BSS 1 Allocates 1 ¥ord of 

Storage to "A" 

B BSS 1 Allocates 1 Word of 

Storage to "B" 
HOLD BSS 1 Allocates 1 Vord of 

Storage to "HOLD" 

The BSS instniction is a pseudo-instruction (explained on 
page 6o) . The important thing to remember is that any 
symbol used in the address, tag, or decrement part of an 
instruction must be defined in the LOC field, as shown above. 

The symbol itself may be anything the programmer desires, 
but it must be six characters or less, in length and there 
must be at least one non-numeric character. 

If a symbol is used in the address field , but does not ap- 
pear in the location field , it is undefined . If it appears 
more than once in the location field , it is multiple - 
defined . In either case, the program will not be executed 
by the computer. 



CLA 


A 


ADD 


B 


STO 


HOLD 


HTR 


END 
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Lesson 5» (cont'd) 

ADDITIONAL EXAMPLE ; 

1. Store into symbolic location X, the sum of the contents 
of locations A and B. If the sum is zero, do not store the 
sum into X, Instead, store the contents of symbolic loca- 
tion FEED 1 into X. 



LOG 



OP 



ADDRESS 



REMARKS 



CLA 


A 


ADD 


B 


TZE 


JUMP 



y STORE 

/ STOP 
\ JUMP 



STO 

HTR 
CLA 
TRA 



STOP 
FEED J 
STORE 



A 
B 
FEED 



BSS 

BSS 

1 BSS 



1 
1 
1 



Move "A" into AC 

Add A + B 

If sum is zero, go to JUMP 

for next instruction 

If not zero, store sum into 

X 

Halt - end of job 

Move "FEED 1" into AC 

Transfer back to loc . 

STORE, which will now move 

FEED 1 (which is in the AC) 

into X, 

'Assigns storage Locations 
to A, B, Euid FEED 1 



Notice that each symbol in the address field has just one 
counterpart in the location field . 

The word JUMP was arbitrarily used to jump the program if 
the sum was zero. Any other symbol would have worked just 
as well, as long as it was carried over to the location 
field (Jl, XYZ, or whatever). 

A symbol was placed in the location field of the STORE in- 
struction so that a return could be made on the TRANSFER . 
This was not absolutely necessary, but it saved two in- 
structions, because after moving FEED 1 into the AC, we 
have to store it into X, then Halt. These two instructions 
were already available to us, therefore it was not neces- 
sary to repeat them. This little procedure is called a 
loop .* 

Any symbol may be used in the address field as many times 
as is necessary, but it may only be defined in the location 
field once. 

Study the above example until it is completely clear before 
continuing with the problems on page 57 • 

* If a certain group of instructions are to be executed 
several times during the course of a program, it is ex- 
tremely wasteful to repeat the instructions over and over 
again. It is more practical to include a few instructions 
that will take care of any necessary modifications and that 
will allow the single set of instructions to be used re- 
peatedly but coded only once. The exeunple above is not 
really a loop since it is not to be repeated over and over, 
but it will give the student an idea of how a loop works 
without going into the details of address modification. 
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I^esson 5f (cont'd) 

WORK AREA 

PROBLEMS : ¥rite in "symbolic", 

67. Compute A - B. If an overflow occurs, store result 
in Y. Otherwise store result in Z. 

LOG OP ADDRESS REMARKS 



2 
68. Compute AX + X (fixed length numbers). Place the 
sum into symbolic location T, If the sum is zero, place 
the contents of symbolic location P into T instead of the 
sum of the original computation. 

LOC OP ADDRESS REMARKS 
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Lesson 5, (cont'd) 



PROBLEMS ; 



CORRECT ANSWERS 



67. LOG 



OP 



ADDRESS 



REMARKS 



END 



CLA 
SUB 
TOV 

STO 

HTR 



A 
B 
Jl 

Z 

END 



Move "A" into AC 

Subtract A - B 

If overflow, go to Jl for 

next instr. 

No overflow, store result 

into Z 

Halt - end of job 



Jl 



STO 

TRA 



Y 
END 



Store result into Y 
Transfer to loc. END, which 
halts the progreim. 



A 
B 
Y 
Z 



BSS 
BSS 
BSS 
BSS 



1 
1 
1 
1 



Allocate store locations 
to A, B, Y Eind Z 



68. 



LOC 



OP 



ADDRESS 



REMARKS 





LDQ 


X 




MPY 


X 




STO 


HOLD 




LDQ 


A 


MPY 


MPY 


X 




ADD 


HOLD 




TZE 


Jl 


STORE 


STO 


T 


END 


HTR 


END 


Jl 


CLA 


P 




TRA 


STORE 



Move X into MQ „ 

Multiply by X (X ) 

Move into temporary 

storage loc. 

Move "A" into MQ 

Multiply by X 

Add X^ to product 

If sum is zero, go to Jl 

for next instr. 

If not zero, place sum 

into T 

Halt - end of job 



Move "P" into AC 

Go to loc. STORE for next 

instr. (this will move "P" 

(now in AC) into "T" , then 

halt) 



A 


BSS 


1 


X 


BSS 


1 


T 


BSS 


1 


P 


BSS 


1 



Allocate Store locations 
to A, X, T and P 
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Lesson 5» (cont'd) 

SYMBOLIC CODING SHEET ; Pre-printed sheets are available to 
the programmer to be used in program writing. The following 
is a typical coding sheet layout: 



709 SYMBOLIC CODING SHEET 
PROGRAM ^JOB NO. DATE PAGE OF 


LOCATION 
', . . , .6 


7 


OPERATION 
8 J5 


ADDRESS, TAG, DECREMENT COMMENTS 
16 72 


IDENTIFICATION 
73 80 























LOCATION - Start in Column 1. A symbol is used here if the 
program is to refer back to a previous instruction (example: 
pag. 56, TRA store). Also used to jump the program away 
from the normal flow (example: pg 56, TZE JUMP). Also used 
to define any symbol used in the original problem (example: 
pg 56, BSS A, D, FEED l) . 

OPERATION - Start in Column 8. Symbolic Op Code, 3 to 7 
characters in length. 

ADDRESS. TAG. DECREMENT - May start in column 12, but 
better to always start in column I6 . There must be at 
least one blank between Op Code and the variable field. 
Address, tag and decrement are to be separated by commas* 
If remarks are used, separate from the last variable field 
by a blank. 

IDENTIFICATION - First card is generally marked with a de- 
scriptive title and the rest of the cards numbered sequen- 
tially (0000, 0010, 0020, etc.). There are two reasons for 
this: (1) if you wish to find a card in a large program, it 
is easy to check the number on the program print-out and go 
right to it and (2) if the card deck should accidentally be 
dropped, it can easily be sorted back into order, Coltomrts 
73-80 may be left blank. 

In writing the little practice problems, always remember 
that if coding sheets were available, LOC would start in 
column 1, OP would start in column 8 and ADDRESS, in 
column 16. 

Special symbols must be used for the assembly program to 
recognize symbol arithmetic in the variable field. The 
symbols are as follows: 

Add + 

Subtract - 

Multiply * 

Divide / 
Multiply A by B, may no longer be written AB, as in normal 
algebraic notation. It must be written: A * B. 
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Lesson 5, (cont^d) 

PSEUDO OPERATION CODES : These codes are so named because 
they are not true machine operation codes. They do not 
have an Octal equivalent and they do not become a part of 
the actual program. They are instructions to (FAP) the 
assembly program (which will change the symbolic program 
written by the programmer into Binary form) , executed by 
the assembly program and then forgotten. 



PSEUDO OP ; COUNT 

DESCRIPTION : This must be the first card of the symbolic 
card deck (refer to page x in introduction) . The total 
number of cards in the program deck will be specified in 
the address field - written as a decimal integer. 



PSEUDO OP ; END 

DESCRIPTION : This must be the last card of the symbolic 
card deck. It tells the assembly program that the symbolic 
program being converted to Binary, is finished. The END 
card must be in every program. 



PSEUDO OP ; BSS (Block Started by Symbol) 

DESCRIPTION ; This causes the assembly progreim to reserve 
a block of storage locations. The number specified in the 
address portion of the instruction indicates the number of 
storage locations to be reserved. It does not indicate a 
storage address (see pages 55 and 56 for examples of BSS). 

The programmer should not assume that locations reserved 
by BSS contain zeros. It is always safer to use the STZ 
instruction to clear these areas out prior to using them 
for processing. 
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Lesson 5» (cont'd) 



WORK AREA 



PROBLEM i 



69, Compute: A*X+B*Y=T (fixed point numbers). 
Store T in location Z. If £in overflow occurs, store 
product of A * X into location P and product of B * Y into 
location Q and Halt. If result of addition is zero, place 
the cpntents of location A into location Z and Halt, If 
not zero, original computation is OK, so Halt program. 
Flow-chart this problem before attempting to code it. Use 
the pseudo op. codes that are necessary. 



LOG OP 



ADDRESS REMARKS LOG 



OP 



ADDRESS REMARKS 
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PROBLEM ; 
69. 



CORRECT ANSWER 



Tstart] — » 



LOAD A 
INTO MQ 



MULTIPLY 
BY X 



STORE 

PRODUCT 

TEMPORARILY 



LOAD B 
INTO MQ 



MULTIPLY 
BY Y 



STORE 

PRODUCT 

TEMPORARILY 



ADD THE 
PRODUCTS TO 
6ETT 



T 



STORE T 


^...^'"'^ST F0R"^^n5? 


A KX 




B ^Y 


INTO 


^^OVERFLOW,,-''^ 


INTO 


— »■ 


INTO 


LOCATION Z 


^^ "VV^ 


LOCATION P 




LOCATION Q 



LOG OP ADDR REMARKS 



IS 
RESULT 
?ERO| 

NO 



YES 



MOVE A 
INTO AC 



J- 





COUNT 


30 




LDQ 


A 




MPY 


X 




STO 


HOLD 




LDQ 


B 




MPY 


Y 




STO 


HOLD 




ADD 


HOLD 




STO 


Z 




TOV 


Jl 




TZE 


J2 




END HTR 


END 



Total of 30 instructions 

Load A into MQ 

Multiply by X 

Store temporarily 

Load B into MQ 

Multiply by Y 

Store temp, but it is 

still in AC also 

Add two products 

Total into loc, Z 

Go to Jl if overflow 

Go to J2 if zero 

If neither overflow nor 

zero - Halt 

This is the end of the main program. The 
rest is used only if overflow occurs (Jl) 
or if the sum is zero (J2). Allocation of 
storage locations is necessary to define 
the symbols used in the address field. 



STORE INTO 
LOCATION Z 



HALT ^ 

END-OF-JOB J 



« 
(ft 

O 
3 



o 
o 

S 



LOC OP 



ADDR 



Jl 



REMARKS 



CLA 
STO 
CLA 
STO 
TRA 



HOLD 

P 

HOLD 

Q 

END 



Move HOLD into AC 

Store into loc. P 

Move HOLD 1 into AC 

Store into loc, Q 

Transfer to loc. END, which halts 

the progrsun 



J2 



CLA 
STO 
TRA 



A 
Z 
END 



Move A into AC 
Store into loc, Z 
Transfer to END - Halt 



Y 

A 

X 

HOLD 

B 

HOLDl 

Z 

P 

Q 

Count 
place 



BSS 

BSS 

BSS 

BSS 

BSS 

BSS 

BSS 

BSS 

BSS 

END 
up t 
into 



^Allocate storage locations to 
symbols used in the program 



/ 



Last card 
otal number of instructions used and 
address field of first card (COUNT), 



Lesson 5» (cont'd) 

SYMBOLIC LANGUAGE ; In discussing symbolic coding (page 55), 
ve ij.a.ve insn«/Xone<j. bnau SjrmuOj-s ma-y ue used as long as 'tiiey 
are defined in the program. It may be worth while to give 
a definition of the various types of symbols and the naimes 
of each type, 

ELEMENT - any plain symbol is called an element . 

(i.e. AA, BETA, HOLD, END^ TOTAL, Al, A2 , A3) 



TERM - a combination of elements, separated by the multiply 
(*) or divide (/) signs, are called terms , 
(i.e. A * B, X^ / D, X '* Y * Z, SUBTOT / CONST) 



EXPRESSION - terms and elements, separated by the add (+) or 
subtract (-) signs, are called expressions , 
(i.e. A*B+Z,A/B-X, A9+ HOLD - X * Y) 

USE OF ASTERISKS AND PLUS OR MINUS ; The * (asterisk) is 
the sign used for multiply, but it has a variety of other 
uses in coding. Some of these may be shown by the follow- 
ing examples ; 

OP ADDRESS MEANING 

TRA * + 3 Transfer to "present location of 

the instruction" plus 3 (in other 

words, transf. to 3 instr, past the 

transfer instruction) , 
TRA * - k Transfer to "present loc. of the 

instr.** minus 4, 
CLA * + 2 Clear and Add "present loc. of 

instr." + 2. 
STO * * 2 Store into this location times 2 (or 

double what is in this location. ) 
CLA* * * Go to loc, 0000 and use the address 

and tag of 0000 to get the location 

to put into AC, 

It is also possible to use a symbol + or -, as follows; 

TRA HOLD + 2 Transfer to the location containing 

HOLD, plus two instructions (in 
other words, the second instruction 
past HOLD in the program) , This is 
very handy for loops . 
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Lesson 5, (cont'd) 
EXAMPLES : 

1, Suppose that somewhere in a prograjn, you wajit to be sure 
that the Divide Check Indicator is Off, This would be 
accomplished in the following manner: 

OP ADDRESS BEMARKS 

DOT Test Indicator and turn if Off 

TRA * + 1 Trans, to next instruction in 

sequence 

It would not have been right to continue right on with 
the program after giving the DOT, because under one 
condition the computer teikes the next instruction and 
under another condition it skips one instruction. A 
NOP could also have been used instead of the TRA * + 1. 

2. On a Halt or Transfer instruction (HTR) , we have been 
using the same symbol in the Loc. and Address fields 
to make sure that the prograjn comes to a permanent 
halt. This may be accomplished very simply as follows; 

OP ADDRESS 

HTR * 

This accomplishes the same purpose because when the 
operator pushes the START button, the program goes 
right back to the Halt instruction and the machine 
will not restart. 

Simply remember that the first * in address field 
indicates location emd the second indicates multiply. 



ADDRESS 



100.« — times 100 
•location of itself 
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Lesson 5» (cont'd) 

PROBLEM ; 

70. Three fixed point numbers are stored in loc. STO 1, 
STO 2 and STO 3. Find the number which is algebrai- 
cally the largest and check the sign. If it is minus, 
place in loc. HOLD and halt. If it is plus, place in 
loc. STAND and halt. 

FLOV CHARTING : 

The importance of flow charting can not be over- 
emphasized. A problem such as the one above, should not be 
coded by a novice, until it is analyzed and flow charted. 

Flow charting may be generalized or detailed depending 
on the desires and needs of the programmer, but usually, 
the larger and more complex the problem, the more detailed 
the flow chart should become. 

It is extremely important to follow the problem 
through all possible paths until a logical conclusion is 
reached. The flow chart is a map £ind should be followed 
when coding a problem. How the map is drawn is not 
important as long as it is understandable to anyone who 
looks at it. For this reason, it is a good policy to use 
standardized symbols, such as the ones shown on page ix, at 
the beginning of the book. 

Always flow chart the normal flow of the operation 
first, leaving the unusual possibilities hanging open. 
Then go back and run down each possibility in turn until 
all are covered. Never leave any loose ends open as the 
computer has no way of deciding what to do if it hits a 
loose end. 

A programmer is responsible for any run he writes 
even after a considerable length of time has elapsed and 
it is no longer fresh in his mind. If changes or modifi- 
cations need to be made at a later date, he can refresh 
his memory by reviewing the flow chart and he can insert 
the change more easily by understanding just where in the 
program it should go. 

The program shown above is repeated on the following 
page and the analysis and development of a flow chart is 
shown. The problem is to be coded on page 67, 
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Lesson 5» (cont'd) 

PROBLEM 70 - (Restated) 

Three fixed point numbers are stored in loc. STO 1, 
STO 2 and STO 3. Find the number which is algebraically 
the largest and check the sign. If it is minus, place in 
loc. HOLD and halt. If it is plus, place in loc. STAND 
and halt. 

First step in the analysis is to determine which one 
of the three numbers is the largest. 



2 IS THE 
LARGEST 



YES 



2>3 ? 





YES 




l>3 9 



YES 



NO 



NO 



I IS THE 
LARGEST 



3 IS THE 
LARGEST 



When the largest number has been located, we must dis- 
cover whether it is plus or minus, then place into HOLD or 
STAND accordingly. 







NO^ 


^ISIT\ 
s^lNUS?/ 


YES 










% 


















' 


' 


PLACI 
STA 


• INTO 
ND 


PLACE 
HOI 


:iNTO 
-D 










' 





( "'^^ ) 



The question "Is it minus?" must be asked three times 
(once for each of the three possibilities in the first half 
of the flow chart). Once the flow chart has been developed, 
the process of coding becomes fairly routine. Of course, 
it is necessary to be familiar with the instructions and 
what each one can do, to make the job of coding easier. 



66 



Lesson 5, (cont'd) 

WORK AREA 
PROBLEM 70 : 
LOG OP ADDRESS REMARKS 
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Lesson 5, (cont'd) 



CORRECT ANSWER 



PROBLEM 70 : 
LOC OP 



ADDRESS 



REMARKS 



START 



END 



COUNT 


30 


STZ 


HOLD 


STZ 


STAND 


CLA 


STO 1 


SUB 


STO 2 


TMI 


C2vs3 


CLA 


STO 1 


SUB 


STO 3 


TMI 


ISLG 


CLA 


ST0 1 


TMI 


ISLG 2 


STO 


STAND 


HTR 


END 


CLA 


STO 2 


SUB 


STO 3 


TMI 


ISLG 


CLA 


STO 2 


TMI 


* + 2 


TRA 


END-1 


STO 


HOLD 


TRA 


END 


CLA 


STO 3 


TMI 


ISLG-2 



NOTE: This instruction ex- 
plained in Lesson 6 

Is 1 >» 2? 

If result -, 1 <C 2, so go to 

cmp 2 vs 3 

If result +, go on to next cmp 

Is 1 > 3? 

If result -, 1 <<! 3, so 3 is 

largest, go to ISLG 

If result +, 1 is largest, move 

back into AC 

If sign -, go to STORE, to place 

in HOLD 

If sign +, store in loc, STAND 

Halt - end of job 



C2vs3 



Is 2 >. 3? 

If sign -, 2 <; 3, so 3 is 

largest, go to ISLG 

If sign +, 2 is largest, move 

back into AC 

If 2 is -, go to STORE, to place 

in HOLD 

If 2 is +, go to STORE, to place 

in STAND 

If 2 is +, store in HOLD 

Go to END, to halt program 



ISLG 



TRA 



END-1 



If 3 is -, go to 2nd Instr. be- 
fore ISLG to store HOLD 
If 3 is +, go to END-1 to store 
STAND 



HOLD 


BSS 


1 


STAND 


BSS 


1 


ST0 1 


BSS 


1 


ST0 2 


BSS 


1 


ST0 3 


BSS 
END 


1 



>Allocate storage locations 
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LESSON 6 



ADDITIONAL INSTRUCTIONS ; 

INSTRUCTION ; DVP (Divide or Proceed) Octal code: +0221 
FORMAT ; (Type B) 



OP CODE 



lA 



S.i 



1112-13 



msk 



TAG 



18-2021 



35 



Description ; This instruction is identical to the DVH in- 
struction (page 29) » with one extremely important exception. 
If division can not take place, the "divide-check" indicator 
turns on as in the DVH instniction, but instead of stopping 
the computer, it continues to the next instruction in se- 
quence* If this instruction is used, it is usual to check 
the indicator immediately after the Divide instmction. with 
a DCT instniction. 

INSTRUCTION ; RND (Round) Octal code: +O76O 0010 
FORMAT ; (Type E) 



OP<^OPE ^/////////}{^^l//j OP CODE 



S,l 



18-20 24 



35 



Description ; Used particularly after divide operations. If 
the product of multiplication is to be rounded, a special 
instruction (Multiply and Round) is available. If position 
1 of the MQ contains a 1, position 35 of the AC is increased 
by 1, If position 1 of the MQ contains a zero, the AC re- 
mains unchemged. In either case, the MQ remains unchanged. 
AC overflow is possible, so a test for overflow should be 
made after the Round instruction, 

INSTRUCTION ; DCT (Divide Check Test) Octal code: +O76O 0012 
FORMAT ; (Type E) 



OPCODE '//////////,'^f^^ 7/// OPCODE 



18-20 23 



35 



S,l II 

Description ; If the Indicator is vix , 
and the computer takes the next instruction in sequence. If 
the Indicator is "off", the next instmiction is skipped emd 
the computer takes the following instruction. 

The Indicator is "on" under two Divide conditions only; (l) 
if the divisor is zero and (2) if the c(AC) are greater than 
or equal to the c(y). The only other way the Indicator may 
be turned "on" was discussed briefly under Floating Divide 
on page hS, 

Usually all "check" indicators are turned off at the begin- 
ning of a program. If a Divide instruction is not carried 
out, the indicator is turned on and the DCT instruction al- 
ways turns it off again. The DCT is usually followed by a 
"Transfer" or "No Operation" instruction (see pages 73 and 
77) • The next instruction in the normal flow of the program 
is always the second instruction after the DCT, 
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Lesson 6, (cont'd) 



EXAMPLES : 



1. 



= T 



Assume fixed point numbers and round the re- 
sults. If division does not take place, put the 
dividend into loc. SET. Otherwise put the 
quotient (t) into loc. GET and the remainder 
into loc. GOT. 



LOC OP 



LDQ 
CLA 
LLS 

DVP 
DOT 

(*)tra 

RND 
STQ 
STO 
HTR 



ADDRESS 



REMARKS 



A Move A into MQ 

ZERO AC Must be cleared before divide 

ZERO To make sign of AC agree with MQ 

(see Note, page 31 ) 
B Divide by B 

Divide-Check Test 
JUMP If no divide, go to loc. JXJMP 

If divide, round result 
GET Put quotient into loc. GET 
GOT Put remainder into loc. GOT 
* Halt - end of job 



JUMP STQ 
HTR 



SET 

* 



Put dividend into loc. SET 
Halt 2 - end of job 



= T Assume fixed point numbers Eind round the result. 
If division does not take place, turn off indi- 
cator and continue program. Otherwise put (t) 
into loc. SET. 



)C OP 


ADDRESS 


LDQ 


A 


CLA 


ZERO 


LLS 


ZERO 


DVP 


B 


DOT 




(**)nop 




RND 




STQ 


SET 



REMARKS 



HTR 



Move A into MQ 

AC Must be cleared before divide 

To make sign of AC agree with MQ 

Divide by B 

To turn off indicator if no div. 

To skip one instruction after DCT 

If divide, round result 

If divide, T into loc. SET (if no 

divide, dividend (a) into loc. 

SET) 

Halt - end of job 



* 
♦ ■it- 



See page 73 
See page 77 
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Lesson 6, (cont'd) 



WORK AREA 



PROBLEMS : 



3 B 



71. A + — = T Assume fixed point numbers and round 

the result. If no division, turn off 
indicator. Place T into loc. HOLD. 
Assume all Binary points at position 
35 (B35). 

LOC OP ADDRESS REMARKS 



72 AH 

' * = T Assume fixed point numbers and round 

result. If no division, place dividend 

into loc. SET. Otherwise place T into 

loc, HOLD and the remainder into loc« 

HOLD + 1. 

LOC OP ADDRESS REMARKS 
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Lesson 6, (cont'd) 



PROBLEMS ; 



71. 



LOG OP 



CORRECT ANSWERS 



ADDRESS REMARKS 



LDQ A Move A into MQ 2 

MPY A Multiply by itself (A„| 

MPY A Multiply by itself (A"^) 

STO TEMP Store into temporary loc, 

CLA ZERO To clear AC prior to Divide 

LDQ B Move B into MQ 

LLS ZERO To make sign of AC agree with MQ 

DVP C Divide by C 

DCT Turn off indicator if no divide 

NOP To skip one instruction 

RND Round result of division 

XCA To move quotient from MQ to AC 

ADD TEMP Add a3 from temp, loc, 

STO HOLD Place T into loc. HOLD 

HTR * Halt - end of job 



72. 



LOC OP 



LDQ 
MPY 
CLA 
LLS 
DVP 
DCT 
TRA 
RND 
STQ 
STO 

HTR 



ADDRESS 



B 

ZERO 
ZERO 
D 

JUMP 

HOLD 
HOLD 



REMARKS 



+ 1 



Move A into MQ 

Multiply by B 

To clear AC prior to Divide 

To make sign of AC agree with MQ 

Divide product of A x B by D 

Divide check test 

If no divide, go to loc. JUMP 

If divide, round result 

Place T into loc, HOLD 

Place remainder into loc, HOLD 

+ 1 

Halt - end of job 



JUMP STQ 
HTR 



SET 

* 



Place dividend into loc. SET 
Halt 2 - end of job 
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Lesson 6, (cont'd) 

INSTRUCTION ; STZ (Store Zeros) Octal code: 
FORMAT ; (Type B) 



+0600 



OP CODE 



lA 



m7^^ 



S.I 1112-13 18-2021 35 

DESCRIPTION ; The c(y) are replaced by zeros. The sign at 
the (y) address is made a plus. This is a very useful in- 
struction. An example of this was shown in Lesson 5» 



INSTRUCTION ; LLS (Long Left Shift) Octal code; 
FORMAT: (Type B) , 



+0763 



OP CODE 



lA 



TAG 



S,l 1112-13 18-2021 35 

DESCRIPTION ; The c(AC), including positions P and Q, and 
the c(MQ) are treated as one long register. The shifting 
of bits to the left is determined by the number placed into 
positions 28-35 of the instruction. This is not to be con- 
fused with an address in storage. The sign of the AC is 
made to agree with the sign of the MQ. If a non-zero bit 
is shifted into position P, the AC overflow indicator is 
turned on and any bits shifted past position Q are lost, 

INSTRUCTION ; LRS (Long Right Shift) Octal code: +O765 
FORMAT; (Type B) 



S,l II 12-13 18-2021 35 

DESCRIPTION : This is identical to the LLS instruction 
above except that the shift is to the right from the AC to 
the MQ. In this instruction, the sign of the MQ is made to 
agree with the sign of the AC and bits shifting past posi- 
tion 35 of the MQ are lost. 

INSTRUCTION ; TRA (Transfer) Octal code; +0020 



OP CODE 


lA 


W/A 


TAG 


Y 



FORMAT ; (Type B) 



OPCODE 



lA 



TAG 



S,l 1112-13 18-2021 35 

DESCRIPTION ; This instxniction is used as an unconditional 
transfer. The computer teikes its next instruction from the 
storage location specified in the (y) address portion of 
the instruction. 
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Lesson 6, (cont'd) 

EXAMPLES ; 

1, ¥e want the sign of A to be the same as the sign of B. 
Show a partial prograun to accomplish this. 



OP ADDRESS 



REMARKS 



LDQ B 
CLA A 
LLS 



Place B into MQ 

Place A into AC 

Nothing moves except the sign from B 

(in MQ) to A (in AC) 



This could also be done with a long right shift: 

OP ADDRESS REMARKS 

LDQ A Place A into MQ 

CLA B Place B into AC 

LRS Moves sign from B (in AC) to A (in MQ) 

2. We want to multiply two fixed point numbers (a+B) and we 
want the most significant digits to be to the right of the 
Binary point, which is to be between positions 17 and 18 
(B17). Show a partial program to accomplish this. 



OP 



ADDRESS 



REMARKS 



LDQ A 
MPY B 
LRS 17 



Place A into MQ 
Multiply by B 

The Binary point in fixed point numbers 
is always assumed to be in front of the 
first position, unless otherwise indi-. 
cated. Therefore, the product (in AC) 
must be moved right 17 positions to 
place it to the right of the desired 
Binary point position. 



Before the LRS: 



PRODUCT 
^ ^ AC 



XXXXXXXXX 



MQ 



BINARY POINT 



After the LRS: 



AC 



PRODUCT 



XXXXXXXXX 



MQ 



1718 

BINARY POINT 
In this case, since all the action was in the AC, the ARS 
instruction could have been used equally effectively. The 
only difference is that with the LRS, the sign of the MQ 
is made to agree with the sign of the AC, 
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Lesson 6, (cont'd) 



WORK AREA 



PROBLEMS 



73. Assume two fixed point numbers (A and B) with the 

Binary point of each fixed between positions 18 and 19 
(b 18). Multiply A by B and place the product from the 
AC into Loc. C. Where will the Binary point be lo- 
cated within location C. Show the location of the 
Binary point in the AC-MQ before the final Move in- 
struction is given. 



Word A 



n 



18 19 



Word B 



Q 



18 19 



AG 



MQ 



Word C 



P 



7^. In the problem above, shift left so that the Binary 
point will be between positions 18 and 19 of the AC. 
Show a partial program to accomplish this. 



LOC 



OP 



ADDRESS 



REMARKS 



LDQ 
MPY 
LLS 

STO 

HTR 



A 
B 



Place A into MQ 
Multiply by B 
Shift left ? posi- 
tions 

Store from AC into 
Loc. C 
Halt - end of job 
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Lesson 6, (cont'd) 



PROBLEMS ; 



73. 



CORRECT ANSWER 





AC 




MQ 




1—1 



R 



I z 
ABINARY POINT 



WORD C 



(NO BINARY POINT) 



The Binary point will be between positions 1 and 2 of the 
MQ. As in any problem in multiplication, the product will 
have as many Binary points as the sum of the digits to the 
right of the positions in the two numbers being multiplied (l8 
+ 18 = 36). Since the product fills the entire AC and MQ, 
the 36 rightmost positions will be beyond the Binary point. 
Therefore, there will be no Binary point in the AC or in 
Word C. 

In decimal arithmetic, if you multiply XX. XXX by X.XXX, the 
product will have six decimal places. It is no different 
in Binary multiplication. 



7^. 



LOG 



OP 



ADDRESS 



REMARKS 



LDQ 


A 


Place A into MQ 


MPY 


B 


Multiply by B 


LLS 


18 


Shift left 18 posi 
tions 


STO 


C 


Store from AC into 
Loc. C 


HTR 


♦ 


Halt - end of job 



The Binary point was in the MQ, between positions 1 and 2, 
The long Left Shift 18 would move the point 18 positions 
to the left, between 18 and 19 of the AC. 






AC 


— 


MQ 


■ • 1 111. 





QPI 



1819 
A 



35 



4 
.J 



35 



17 



1 = 18 
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Lesson 6, (cont'd) 

INSTRUCTION ; CAS (Compare AC with Storage) Octal code: +0340 
FORMAT: TType B) 



OP CODE 



lA 



TAG 



S.I 



1112-13 



18-2021 



35 



DESCRIPTION ; This is the only instruction that allows for 
a three way branch. 

1, If the c(ac) are algebraically greater than 
the c(y), the computer takes the next instniction in se- 
quence. 

2, If the c(AC) are algebraically equal to 
the c(Y/ , the computer skips one instiniction. 

3, If the c(AC) are algebraically less than 
the c(y), the computer skips two instinictions . 

This could be flow charted as follows: 

This should cause 
the program to 
branch to a sub- 
routine away from 
the main flow of 
the program. 



AC<; Y 

SKIP TWO 

INSTRUCTIONS 



This continues 
the main flow of 
the program. 




AC > Y 
«0 TO NEXT 
INSTRUCTION 



AC=Y 

SKIP ONE 

INSTRUCTION 



This should also cause 
the program to branch 
away from the main flow. 



EXAMPLE : 
LOC 



OP 



ADDRESS REMARKS 



100 CAS 350 Compare AC with Loc» 350 

101 (if c(AC) > c(350), the computer takes this instr,) 

102 (if c(ac) = c(350), the computer takes this instr,) 

103 (if c(ac) <C c(350), the computer takes this instr.) 



INSTRUCTION: NOP (No Operation) Octal code: +O76I 
FORMAT ; (Type D) 



OPCODE 



DESCRIPTION ; 



S,l II 

This causes no action on the part of the com- 
puter. It merely skips this instruction and continues to 
the next instruction in sequence. One example of the use 
of NOP was shown on page 70, Another use would be if only 
a two way decision is needed after the CAS instruction. 
For example, if both the > ajid = should take the program 
to the same place, the instruction after CAS should be NOP, 
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Lesson 6, (cont'd) 

EXAMPLE ; Use locations as in previous examples. 

Compute in floating point: (a + b)c= T Compare T with 
c(SET). If T;>'c(SET), subtract A - B euid store result in 
GET. Otherwise store T in Loc. GET + 1. 



LOC 



OP 



ADDRESS 



REMARKS 



CLA 


A 


FAD 


B 


XCA 




FMP 


C 


CAS 


SET 


TRA 


JUMP 


NOP 




STO 


GET + 1 


HTR 


* 


CLA 


A 


FSB 


B 


STO 


GET 


HTR 


* 



Move A into AC 
Add B to A 

Move sum from AC to MQ to pre- 
pare for multiplication 
Multiply by C 
Compare AC with c(SET) 
If AC ^>- , take next instr, from 
loc. JUMP 

Skip = compare, since both = and 
<C go the same way 
If -"d or =, store T into Loc. 
GET + 1 
Halt - end of job 



Move A into AC 
Subtract A - B 
Store into Loc. GET 
Halt 2 - end of job 
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Lesson 6, (cont'd) 



PROBLEM ; 

Use locations as in previous problems. 

75. Compare A and B, If A>B, store A in loc. SET and 
B in loc, BET, If A = B, store A in loc. SET and B 
in loc. GET. If A <CB, store A in loc. SET and B in 
loc. LET. 

It would be worth while to take a piece of scratch 
paper and flow chart this problem before attempting to 
code it. Always use as few instructions as possible. 

LOC OP ADDRESS REMARKS 



79 



Lesson 6, (cont'd) 



PROB LEM; 
75. 




START 



MOVE A 
INTO AC 



CORRECT ANSWER 



STORE A 
INTO SET 



STORE B 


-< 


\a:b/ 


> 


STORE B 


INTO LET 






INTO BET 






s 










STORE B 
INTO GET 
















i 






\ 







LOG 



OP 



c 



HALT 
END- OF- JOB 



) 



ADDRESS 



liEMAWCS 



CLA A Move A into AC 

STO SET Store A into loo, SET 

CAS B Compare A (in AC) with B 

TRA JUMP If AC >► , go to loc . JUMP 

TRA JUMP 1 If AC =, go to loc. JXJMP 1 

CLA B Move B into AC 

STO LET AC <: , store B in loc, LET 

HTR * Halt - end of job 



JUMP 



CLA 
STO 
HTR 



B 
BET 

* 



Move B into AC 

Store B into loc. BET 

Halt 2 



JUMP 1 CLA B 

STO GET 
HTR * 



Move B into AC 

Store B into Loc, GET 

Halt 3 



Since A goes into location SET under all three conditions, 
it is easier to do it at the beginning than to repeat it 
three times. 
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LESSON 7 

ADDITIONAL PSEUDO OP. CODES ; 



TJcTTTT'nn nxt 



PZE ^PlUi 



y.f^-nn \ 



DESCRIPTION ; This pseudo op, code is primarily used to pro- 
vide constajits in desired parts of a register. It describes 
one word only and places zeros into the Sign and positions 1 
and 2 of the word. The address, tag, and decrement may be 
specified in the normal manner. 

Examples: PZE Places zeros in Addr. , Tag, and Deer. 

PZE 3 Places a 3 into Address 

PZE 0,3 Places a 3 into Tag 

PZE 0,0,3 Places a 3 into Decrement 

PZE 3,3,3 Places a 3 into all three fields 



Examples of the use of this pseudo op, 
Lesson 8. 



code may be found in 



PSEUDO OP . EQU (Equiva:lent or Equals) 

DESCRIPTION ; This pseudo op. code is used to define a sym- 
bol. It means, "The symbol in the location field is equiva- 
lent to whatever is placed in the Address field." It may 
also be used to equate one symbol to another. 



Examples : 



Hold EQU 300 

CLA ALPHA*1I0LD 



Hold = 300 

move ALPHA multiplied by 300 

(hold) into AC. 



A 
X 



EQU 10 
EQU 3*2 



+ 2 



A = 10 
X = 8 



PSEUDO OP . OCT (Octal Data) 

DESCRIPTION ; This pseudo op. code defines a constant as sm 
Octal number. If the niomber of digits written in the ad- 
dress field is less than 12, the assembly program always 
right adjusts. 

Example: It is desired to place all (Binary) ones into a 



word called X. 
LOC. 



OP. 



ADDRESS 



OCT 



-377777777777 



The word in storage will look like this: 



.'■'■'.'■'■'■'■'■',•*- 



■♦ I 



- 3 7 7 7 
If we wish to fill positions 24-35 of word X with 4567g 

LOC OP ADDRESS 



OCT 



4567 







Result : 



0*- 



01 00 I I I I I I I 
■ ■ ■ I i_i I I I — 1—1 I— 



(right adjusted) 
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Lesson 7» (cont'd) 

PSEUDO OP ; DEC (Decimal Data) 

DESCRIPTION ; This pseudo op, code defines a constant as a 
Decimal number. The following three rules must be observed 
in writing constants in Decimal notation. 

1. If floating point, must contain decimal point (,) or 
(e), but not (b). 

2. If fixed point, must contain (b) or be completely 
free of all three signs (,) (e) (b). 

3. If data contains (b) , it is fixed point even if (,) 
or (e) is also used. 

Examples: fixed point numbers (refer back to page 3?) 

LOG OP ADDRESS 

X DEC 11B32 the number 32 designates the Binary point 
position. 



(11^0 = 138) °°'°" 



_i I I — I — I 1 — I I u 



27_^ ^2 35 
X DEC 11,B32 (same as above) | ^^ 

X DEC 11B5 Binary point after position 5: ' ^O.l.O.l.i. 

I 5 
+ 1 ^ 
X DEC 11 If Binary point is not designated, it is 
presumed to be after position 35* 

floating point numbers 

X DEC 3.1^15926B6 non- integer (has fraction part) 
Binary point at position 8 

X DEC HE (in floating point, the Binary point is 
always fixed between positions 8 and 9) 

.10 



X 


DEC 


IIEIO This means: 


11 X 10 


X 


DEC 


11E3 This meems: 


11 X 10^ 


X 


DEC 


11.9 





The only limitations to the number of Decimal numbers that 
may be written in one line is that they may not extend be- 
yond column 71 and that they must be separated by commas. 

FAP recognizes Decimal, Octal, and Hollerith data. 
Hollerith is used primarily for headings £ind titles and will 
not be discussed in detail here. Sufficient to say that 
Hollerith was one of the developers of electrical contact 
reading for the I89O census. His work led to the present 
day punched card system and his neune is associated with cer- 
tain notation, primarily alphabetic, which is made accept- 
able to the computer by the use of the BCI or BCD pseudo op, 
codes or a literal (mentioned on the next page). 
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Lesson 7» (cont'd) 

USE OF CONSTANTS AND LITERA.LS : Most programs deal with 
a certain amount of data aind very few programs are written 
without the use of a number of constEints. Constants are 
usually made a part of the program, while the data, although 
it may be part of the program, usually is used at the time 
the program is executed, 

A literal is specified by the equal (=) sign located in 
position 16 of the Coding Sheet (first position of the Ad- 
dress field). Literals are usually not used with pseudo op, 
codes and they are most easily explained by examples, as 
follows: 

OP ADDRESS REMARKS 

SUB = 5 Subtract 5 

ADD = 5 Add 5 

= ^2777 Octal literal (277?) 

= H JONES Hollerith literal ( JONES ) 

Constants are usually set up with the pseudo op, codes 
OCT or DEC. There are times when it is more practical to 
use a literal. For example, if we were to add 5 to a se- 
quence of numbers, it could be accomplished in either of 
two ways: (l) when the place to add was reached simply write 
the instruction: (ADD = 5) and (2) set up a constant with 
some label such as NOW (NOW DEC 5), and when the place to 
add was reached, write the instruction (ADD NOW), This 
second method teikes one additional instniction to define 
the consteuit (5)» 

EXAMPLES OF OCTAL AND DECIMAL CONSTANTS ; 

1. Show the Octal representation of the bits in 
a storage location, of the following: (each Octal no. rep- 
resents 3 Binary digits except the first, which represents 
only 2), 

a, DEC -7 -000000000007 

b, DEC 9 +000000000011 

c, DEC 18 +000000000022 

d, DEC llBll +001300000000 

A 

e, DEC 11,B29 +000000001300 

A 
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Lesson 7, (cont'd) 



EXAMPLES — c ont inued 
f. DEC IIBO 



g. DEC .125B0 



h. OCT -2777 
i. OCT 123^5 
j , Floating Point 

1. DEC 7E - 6 

2. DEC 1. 



+000000000000 

This would shift the entire number 
out of the register as the Binary- 
point (or unit position of the num- 
ber) is to be in the zero position. 

+040000000000 

Here the Binary point is zero 
again, but the fraction part will 
go to the right of the point, 
.125j^Q = .Ig = O.OOl^ In Binary, 

the word would look like this: 

ra 

100 — 



+A0 4 
-000000002777 

+0000000123^*5 

(refer to page hi) 
This means: 7 x 10 
char. 



-6 



mantissa 



In Binary: l^i OOO 00 I 

1—1 I I I I I L. 



I 

_1 I L. 



+ 2 



In Octal; 



\0= ^8 = 001.2 



2 4 



Normalized . 1x2 
(200g + 15=2013) 



3. DEC 5.17E2 This means: 5.17 = 10 

517 j^Q = 1005g = 001000000101. 2 



12 



(200„ + 12o = 212„) 



= .100000010100 X 2 
^8 " ^"8 
char. 



(Octal) 

si 

mantissa 



I 2 



4 2 4 
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Lesson 7» (cont'd) 



WORK AREA 



PROBLEMS : 



76. Show the Octal representation of the following 
constants: (Also indicate the sign) 



a. DEC 35 



q 



b. DEC 35. 



c. OCT -377777 



R 



d. DEC 27B26 



e, OCT (blank) 



f. DEC -3.5E1 



g. DEC .171875 



h. DEC 5.U98BO 
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Lesson 7, (cont'd) 



CORRECT ANSWER 



PROBLEM 76 ; 



a. 



000000000043 Fixed point 



b. 



206^30000 Floating point because of the 

decimal point. 



000000377777 Right adjusted 



d. 



000000033000 Binary point fixed at posi- 
tion 26. 



e. 



000000000000 Blank after the pseudo-op. 

code means zero. 





- 




f. 


206430000000 



35io = ^38 = 100011.2 = 
.100011x26(200g+6g = 206g) 



E' 



176540000000 



,171875, n = •130a = 



'10 



8 



-2 



h. 



377000000000 



.OOlOllOOOg = .101100 X 2 
12810 - ^10 = 126^0 = 1763 



.498^0 = .3778 

the whole number is lost, 
since the Binary point is 
set at zero 



Examples of the use of a constant in a progrcim may be 
found on pages 100 and 102, 
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Lesson 7» (cont'd) 



WORK AREA 



PROBLEM ; 

77, Fifty floating point numbers are in loo. A through 
A + 49, All words that are equal to 3, will be added and 
placed into loc. B, Display B in the MQ when job is done. 
Flow chart the problem before attempting to code it. 

LOG OP VARIABLE REMARKS 
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Lesson 7, (cont'd) 



CORRECT ANSWER 



PROBLEM 77 ! 




LOC 



OP 



VARIABLE 



REMARKS 



ZERO B AND 

AN AREA FOR 

COUNTING 



COUNT 
STZ 
STZ 
PICKUP CLA 
CAS 
TRA 

TRA 




INCREASE 
PICKUP 
BY I 



INCREASE 
COUNTER 
BY 




MOVE B 
INTO MQ 



f HALT J 



BUMP 



ADD TO B 

AND STORE 

IN B 



CLA 
ADD 

STO 
CLA 
ADD 
STO 
SUB 

TZE 

TRA 



EQUAL 



FAD 
STO 
TRA 



THRU 



LDQ 
HTR 



28 

B 

COUNTR 

A 

THREE 

*+2 

EQUAL 



Move A into AC 

compare AC with 3 

not equal , go to 2nd 

instr. 

is =, go to EQUAL 

routine 



PICKUP 
ONE 

PICKUP 

COUNTR 

ONE 

COUNTR 

FIFTY 

THRU 
PICKUP 



I Increase A to A + 1, 
J etc, (see Note below) 



} 



Increase counter by 1 

To check if cotinter 
= 50 

If = 50, go to THRU 
Otherwise , back to 
PICKUP to go through 
loop again 



B 
B 
BUMP 



Add to B 

Store in B 

go back to BUMP rout. 



B 

* 



Move B to MQ 
Halt - end of .job 



COUNTR 


PZE 




B 


PZE 




A 


BSS 


50 


THREE 


DEC 


3.0 


ONE 


DEC 


1 


FIFTY 


DEC 

END 


50 



Note: Address modification is covered in Les- 
son 8, Essentially, the three instructions 
used here modify the address, using algebraic 
addition. This type of progreunming must be 
done very carefully because of the possibility 
of making mistakes. All variables involved 
here are positive. If the instruction at PICK- 
UP had a negative operation code, the desired 
address modification would not be obtained. 
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Lesson 7i (cont'd) 

INSTRUCTIONS ; The instructions that follow make it possible 

bU S UUX'C; ^CX^ 1/ UX t/11^7 «.^\^^1. i^Ol.1. bO \JX L»±^0 -c^kv^ J-AX t^ «^ 1/XJ.C; \^KJXJ.^O — 

ponding part of a word in storage. 

INSTRUCTION ;- STA (Store address) Octal code: +0621 
FORMAT ; (Type B) 



OP CODE 


lA 


M 


TAG 


Y 



S.I 



1 1 12-13 



18-2021 



35 



DESCRIPTION ; The c(AC) positions 21-35» replace the c(y) 
positions 21-35. The contents of Y (Sl-20) and the c(ac) 
remain unchanged. 

INSTRUCTION ; STD (Store DECREMENT) Octal code: +0622 
FORMAT; [TyP© B) 



OP CODE 


lA 


'm 


TAG 


Y 



S,l 



1112-13 



18-2021 



35 



DESCRIPTION ; The c(ac) positions 3-1? replace the c(y) 
positions 3-17. The contents of Y (S, 1,2, 18-35) and the 
c(AC) remain unchanged, 

INSTRUCTION ; STT (Store TAG) Octal code; +0625 
FORMAT; (Type B) 



OP CODE 


lA 


M 


TAG 


Y 



S,l 



1112-13 



18-2021 



35 



DESCRIPTION : The c(AC) positions 18-20 replace the c(y) 
positions 18-20. The contents of Y (S, 1-1? f 21-35) and 
the c(AC) remain unchanged). 



INSTRUCTION ; STP (Store Prefix) Octal code; +O63O 
FORMAT: (Type B) 



OP CODE 


lA 


'M 


TAG 


Y 



S,l 



1 1 12-13 



18-2021 



35 



DESCRIPTION : The c(AC) positions P, 1, 2 replace the c(y) 
positions S, 1, 2. The contents of Y (3-35) and the c(ac) 
remain unchanged. 
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Lesson 7, (cont'd) 
EXAMPLES ; 

1. Place the TAG of the word presently in location 
TOTAL, into loc, Al. Place the Address into loc. A2. 



LOC 



OP 



ADDRESS 



REMARKS 





COUNT 


11 




STZ 


Al 




STZ 


A2 




CLA 


TOTAL 




STT 


Al 




STA 


A2 




HTR 


* 


TOTAL 


BSS 


1 


Al 


BSS 


1 


A2 


BSS 


1 



Total of 11 cards 
used for program. 
Clear out loc. Al 
Clear out loc. A2 
Move TOTAL into AC 
Store TAG into Al 
Store Address into A2 
Halt 



END 



Allocate storage 

space for symbols 

used 

End of program 



2. The Op. Code of the instruction in loc. HOLD is 
CLA. Store this Op. Code into loc, AB2. This must be done 
in a rather devious way since the instructions just covered 
do not move digits 1-11, 



LOC 



OP 



^ 



MQ 



AC 





MQ 


1 2 3456 78 

1 L_l 1 1__1 ' ■ 


9 1011 
— 1 1 1 



Q 



AC 



I 2345 6 78 
—I I I 



QP 



ADDRESS 



COUNT 10 



STZ 



23 45 6789 lOII LDQ 
—J — I — 1 — I — i— I I I • ■ ^ 



LLS 



AB2 

HOLD 

8 



ALS 

STO 
HTR 



27 



AB2 



REMARKS 



HOLD 
AB2 



BSS 

BSS 
END 



1 
1 



Total of 10 cards in 
program 

Clear out loc, AB2 

Move HOLD into MQ 

Shift left to move 
Op. Code into AC 
(leaving off the last 
3 digits since they 
are Octal zero). 

AC left shift to put 
Op. Code in the 
proper place in AC 

Store from AC to 
loco AB2 

Halt 



^Allocate storage po- 
/ sitions 

End of program. 
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Lesson 7j (cont'd) 

WORK AREA 

PROBLEM ; 

78. A Type B instruction is in location HOLD. Move 
the Op. Code into loc. Bl, the TAG into loc. B2 and the Ad- 
dress into loc. B3. 

LOC OP ADDRESS REMARKS 
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Lesson 7» (cont'd) 



PROBLEM 78 ; 



CORRECT ANSWER 



LOC 



OP ADDRESS 



REMARKS 



COUNT 


' 17 


STZ 


Bl 


STZ 


B2 


STZ 


B3 


LDQ 


HOLD 


LLS 


11 



ALS 



22j 





STO 


Bl 




CLA 


HOLD 




Sl"l' 


B2 




STA 


B3 




HTR 


* 


HOLD 


BSS 


1 


Bl 


BSS 


1 


B2 


BSS 


1 


B3 


BSS 
END 


1 



Move HOLD into MQ 

Shift left 11 places 
to move Op. Code into 
AC (since we do not 
know what the last 
Octal no. of Op. Code 
is, we must move it 
all). 

AC left shift to move 
Op. Code into proper 
position in the AC 
(11 + 2k = 35) 

Store Op, Code into Bl 

Move HOLD into AC 

Move TAG into B2 

Move Address into B3 

Halt - end of job 
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LESSON 8 

USE OF JDJDjEX REGISTERS ; The primary use of Index Registers 
is for purposes of counting and address modification. The 
7090 contains three Index Registers, commonly referred to as 
XRl, XR2, and XRk (please refer back to page I7, par. 3 and 
page 21, definition of TAG), There is no provision for a 
sign, so the contents of an Index Register are always con- 
sidered to be positive. 

PRESUMPTIVE AND EFFECTIVE ADDRESSES ; When an address is to 
be modified by using an Index Register, a TAG is specified. 
In this case, the address of the instruction is not the true 
address , but is called the presumptive address . The true 
address (called the effective address ) is the presumptive 
address minus the contents of the specified Index Register. 

EXAMPLE: CLA 200,2 This tells the computer to place 
the contents of location 200 minus the contents of XR2 into 
the AC, If XR2 contained a 10, the effective instruction 
would be : 

CLA 190 

In this way, the address of the instruction has been modi- 
fied. 

ADDRESS MODIFICATION ; There are many reasons why an address 
should be modified in a program. For example, if we want to 
add a fixed amount to a large number of sequential addresses* 
This could be accomplished by a large series of ADD instruc- 
tions, but it would be extremely wasteful of storage. It is 
much more advantageous to give the ADD instruction once, 
modified by an Index Register which will be incremented or 
decremented in a loop which will continue until all of the 
desired addresses are modified. 

A more detailed exajnple of this process involves in- 
structions which are found on pages 9k and 95. The examples 
on pages 97 and 98 attempt to show the process of address 
modification and counting in greater detail. 

Two, ajid even three, Index Registers may be used, de- 
pending on the complexity of the problem. Pages 103 and 10^ 
go into more detail on the use of multiple Index Registers. 

It is extremely important to understand Indexing and 
the reasoning behind the use of Index Registers because they 
are used very extensively in programming. For this reason 
it is recommended that Lesson 8 be studied and restudied 
until all points have been understood. 
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Lesson 8, (cont'd) 

INSTRUCTIONS ; The following instructions are used to load 
and store the contents of index registers. The TAG speci- 
fies the Index Register (or Registers) to be affected (see 
page 21 for Binary codes for Index Registers. 

INSTRUCTION ; LXA (load Index from Address) Octal code: +0534 
FORMAT : (Type B) 



opccE wmm^-A y 



18- 2021 



35 



DESCRIPTION ; The address part of the c(y) (positions 21-35) 
replaces the number in the specified Index Register (XR) . 
The c(y) are unchanged. 

INSTRUCTION ; LXD (Load Index from Decrement) Octal code: -053^*. 
FORMAT ; (Type b) 



^^mmt^n^ 



S.I II 16-2021 35 

DESCRIPTION ; The decrement part of the c(y) (positions 3- 
17) replaces the number in the specified Index Register (XR) 
The c(y) are unchamged, 

INSTRUCTION ; AXT (Address to Index True) Octal code: +077^ 
FORMAT: (Type B) 



OP CODE 



mum 



TAG 



S,l 



18- 20 21 



35 



DESCRIPTION : This is identical to the LXA instruction above 
except that instead of the contents of Y moving into the 
Index Register, whatever is in Y will move into it. See 
examples on page 96. 

INSTRUCTION : TSX (Transfer and Set Index) Octal code: +007^ 
FORMAT: (Type B) 



OPCODE I A ^^^TAG Y 



S,l 



1112-13 



IS- 2021 



35 



DESCRIPTION : This instruction places the 2's complement of 
the instruction counter contents into the Index Register 
specified by the TAG. 



EXAMPLE: 



10010110 
01101001 

1 

01101010 



I's compl. (simply reverse) 
2's compl, (add l) 
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Lesson 8, (cont'd) 



INSTRUCTIONS : The Tollowing instructions are used to test 
or modify- v,or both test and modify) the contents of the Didex 
Register specified by the TAG. 



INSTRUCTION: TIX (Transfer on Index) Octal code: +2000 
FORMAT ; [Type A) 



OP 



DECREMENT 



TAG 



S,l,23 



1718-2021 



35 



DESCRIPTION ; If the contents of the Index Register, speci- 
fied by the TAG, are greater than the Decrement, the number 
in the Index Register is reduced by the Decrement and the 
next instruction is taken from the location specified by Y. 
Otherwise, the TAG remains unchanged and the computer goes 
on to the next instruction in seouence. 



INSTRUCTION : TXI (Transfer with Index Incremented) 

Octal code: +1000 
FORMAT : (Type A) 



OP 



DECREMENT 



TAG 



S,l,2 3 



1718-2021 



35 



DESCRIPTION : The decrement portion of the instruction (pos. 
3-17) is added to the contents of the Index Register speci- 
fied by the TAG. The resulting sum moves into the Index 
Register and the computer then takes its next instruction 
from the location specified by Y. 

INSTRUCTION : TXL (Transfer on Index Low or Equal) 

Octal code: -3000 
FORMAT : (Type A) 



OP 


DECREMENT 


TAG 


Y 



S,l^3 



1718-2021 



35 



DESCRIPTION : If the contents of the Index Register, speci- 
fied by the TAG, are less than or equal to the Decrement, 
the next instmction is taken from the location specified 
by Y. Otherwise, the computer takes the next instruction 
in sequence. 

INSTRUCTION : TXH (Transfer on Index High) Octal code: +3000 
FORMAT : [Type A) 



OP 


DECREMENT 


TAG 


Y 



S,l,23 



1718-2021 



35 



DESCRIPTION : If the contents of the Index Register, speci- 
fied by the TAG, are greater than the Decrement, the next 
instruction is taken from the location specified by Y. Other- 
wise, the computer takes the next instruction in sequence. 
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Lesson 8, (cont'd) 

EXAMPLES: 

LOG QP VARIABLE FIELD 
(Address, Tag, 
Decrement) 



1. 



LXA HOLD, 2 



REMARKS 



15 is loaded into XR2 (De- 
fined by the PZE below) 



HOLD PZE 15 
2, LXD Jl, 1 



Jl 



PZE 10. 3, 6 



6 is loaded into XRl (The 
PZE defines 10 for Address , 
3 for Tag and 6 for Decre - 
ment,) 



3. 



TSX HOLD, k 
HTR * 



HOLD TRA 1, k 



Computer transfers to loc 
HOLD and sets XRk equal to 
minus the loc of the TSX. 
Thus a transfer to 1, ^ at 
HOLD will return the com- 
puter to the location of 
the TSX plus 1. 



k. 



AXT 200, 1 



This means: move the digits 
200x0 into XRl. Not the 
contents of loc. 200, but 
the actual numbers (200) 
move into XRl. 



5. 



TIX Start, 2, 5 



This means: if c(XR2) are 
greater them, the Decrement 
of 5 * the number in XR2 is 
reduced by 5, and control 
is transferred to location 
START. Otherwise, on to 
the next instruction. 



6. 



7. 



TXI AB2, 2, 7 



This meajis : add Decrement 
of 7 to the c(XR2) and 
tremsfer control to loc AB2. 



TXL HOLD, kf 13 



This means: if c(XR^) are 
less than or equal to the 
Decrement of 13, tremsfer 
control to location HOLD. 
Otherwise, on to the next 
instruction. 



8. 



TXH HOLD, 1, 3 



This means: if c(XRl) are 
greater than the Decrement 
of 3 trajisfer control to 
location HOLD. Otherwise, 
on to the next instruction. 
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Lesson 8, (cont'd) 

EXAMPLE ; 

PROBLEM ; A block of 20 numbers are stored consecutively in 
storage, beginning in location TABLE. Store this block of 
numbers in the same order in storage beginning with location 
XYZ. Show a partial program to accomplish this action. 



LOG 



OP 



VARIABLE FIELD REMARKS 



LXA 
START CLA 

ST0 

TIX 

HTR 



STORE, 2 
Table + 20, 2 

XYZ + 20, 2 

START, 2, 1 



Move 20 to XR2 

Move 1,2,3 through 20 to 

AC 

Move 1 to loc. XYZ, 2 to 

XYZ + 1, etc. 

If c(XR2) is greater than 

1, subtract 1 and go to 

START 

Halt - end of job 



STORE PZE 20 
TABLE BSS 20 
XYZ BSS 20 



Set up one word containing 
20 in address field 
Allocate 20 storage posi- 
tions to TABLE 
Allocate 20 storage posi- 
tions to XYZ 



Let us examine what has been accomplished by this 
progreun; 

(1) Since there are 20 numbers, 20 is loaded into an 
Index Register. 

(2) The CLA instruction moves the first of the 20 num- 
bers into the AC. (it says, "move TABLE + 20 - XR2 (which 
contains 20))," Therefore the first of the 20 numbers in 
loc, TABLE goes into the AG. 

(3) The STO instruction works the same way, XYZ + 20 - 
20 = XYZ. 

{k) The next step is to compare the contents of XR2 with 
the Decrement of 1, The number in XR2 is reduced by the 
Decrement of 1, so XR2 now stands at 19 » the program goes 
back to START and goes through the loop again, moving the 
second number since now we have TABLE +20-19. Again, 1 
drops from the Index Register and this continues tintil XR2 
finally stands at 1, at which time all 20 numbers have been 
moved and since XR2 is equal to the Decrement of 1, the 
program goes on to the HALT ins timet ion and the job is done. 

Please review this example until it is thoroughly 
understood. Read over the TIX instruction on page 95 » as 
this problem demonstrates its use very effectively. 
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Lesson 8, (cont'd) 

EXAMPLE ; Given 50 floating point numbers stored in DATA 
through DATA + k9 » Sum all positive numbers and store in 
location TOTAL, Sum all negative numbers and store in loca- 
tion NEGNO. Show a partial program to accomplish this 
action. 



FLO¥ CHART: 



fsTARTJ* 



ZERO OUT 

TOTAL AND 

NEGNO 



LOG OP 



STZ 

STZ 

AXT 

LOOP CLA 

TMI 

FAD 

STO 



HTR 



NEG 



FAD 



SETUP 
XR =50 



PICK UP 

NUMBER 

TAGGED BY 

XR 




ADO TO 
TOTAL 




ADD TO 
NEGNO 



^ HALT ") 



VARIABLE 



REMARKS 



TOTAL 
NEGNO 
50, 2 
DATA + 50, 2 

NEG 

TOTAL 

TOTAL 



Zero out position TOTAL 

Zero out position on NEGNO 

Set up 50 in XR2 

Move DATA + 50-50 into AC 

This moves in first word (DATA) 

If nvunber is negative, jump 

to loc. NEG. 

If not -, must be +, add to 

whatever is in TOTAL 

Move from AC , back to storage 

loc. TOTAL 



TEST TIX LOOP, 2, 1 



Has XR2 dropped to 1? If not, 
taJce off 1 and go back to 
LOOP (the second time through 
LOOP, move DATA + 50-i^9, or 
DATA + 1 into AC. 
HALT - When the program has 
gone through LOOP 50 times, 
XR2 will = 1 and that is the 
finish of the .1ob, 



NEGNO 





STO 

TRA 


NEGNO 
TEST 


TOTAL 
NEGNO 


BSS 
BSS 


1 
1 



If no, was - in first instr. 

past LOOP, program comes here 

and add to whatever was in 

NEGNO . 

Move from AC to storage loc. 

NEGNO 

Go back to test XR to see if 

finished. 



Allocate 1 position to TOTAL 
Allocate 1 position to NEGNO 

Notice that AXT was used to set up 50 in Index Register, 
rather than LXA. This saves one instruction as we don't 
need to set up a constant with the PZE instruction. 
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Lesson 8, (cont'd) 

¥ORK AREA 

PROBLEM : 

79* Twenty fixed point numbers are stored consecutively, 
starting in location HOLD. Twenty other fixed point num- 
bers are stored consecutively, starting in location STAND, 
Place HOLD - STAND into location TOTAL, HOLD + 1 - STAND + 1 
into loc. TOTAL + 1, HOLD + 2 - STAND + 2 into loc. TOTAL 
+2, etc« If an overflow occurs, replace that difference 
by one bits in all positions of the word. Show a partial 
program to accomplish this action, 

LOC OP VARIABLE FIELD REMARKS 
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Lesson 8, (cont'd) 



PROBLEM 79 ; 



CORRECT ANSWER 



LOG 



OP 



VARIABLE FIELD REMARKS 



TOV 



START 



* + 1 



AXT 


20, 1 


CLA 


HOLD + 20, 1 


SUB 


STAND +20, 1 


TOV 


GO 


STO 


TOTAL +20, 1 


TIX 


START, 1, 1 


HTR 


* 


CLA 


OCTAL 


TRA 


START + 3 



Make sure overflow 

indicator is off. 

Place 20 into XRl 

Move HOLD, HOLD + 1, 

HOLD + 2, etc. to AC 

Subtract HOLD - STAND 

etc. 

If overflow, jiimp to 

GO 

Differences into 

TOTAL, TOTAL + 1, etc 

(or all I's) 

If c(XRl) is greater 

than 1, go to START 

Otherwise HALT - end 

of job. 



GO 



Replace overflow dif- 
ference with all ones. 
Go to third ins t mic- 
tion past START 



OCTAL 



OCT 



-377777777777 



HOLD 


BSS 


20 


STAND 


BSS 


20 


TOTAL 


BSS 


20 



Set up Octal constant 
to produce all ones. 

Allocate storage 
locations 



This works exactly the same as the example shown on 
page 97 • One or two additional things were thrown in, but 
these should not have obscured the basic problem of moving 
a series of numbers from one place in storage to another 
place in storage. 
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Lesson 8, (cont'd) 

WORK AREA 

PROBLEM ; 

80, Generate a table of numbers from through 1000, in 
increments of 5. Store the first number in location 500. 
Show a partial program to accomplish this action. Flow 
chart the problem on scratch paper before starting to code. 

LOG OP VARIABIJ; REMARKS 
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Lesson 8, (cont'd) 



CORRECT ANSWER 



PROBLEM 80. 



fsTARTJ-* 



STORE 

ZEROS 

IN TABLE 



PLACE 

ZEROS 

INTO LOG. 500 



SETUPXR 

WITH 

ZEROS 




INCREASE 

TABLE BY 

5 



ALGEBR. 

SUBTRACT 

1000 



c 



INCREASE 

POSITION 

BY I 



HALT 
ENO-OF-dOB 



) 



LOC 



OP 



VARIABLE 



REMARKS 



LOOP 



STZ 


TABLE 


CLA 


TABLE 


STO 


500 


AXT 


0, 1 


SUB 


= 1000 


TZE 


HALT 


CLA 


TABLE 


ADD 


FIVE 


STO 


TABLE 


TXI 


*+l, 1, -1 


STO 


500, 1 


TRA 


LOOP 



Store zeros into TABLE 
Move TABLE into AC 
Store TABLE (containing 
zeros) into loc, 500 
Set up XRl with zeros 
Algebraic subtract a storage 
position containing 1000 
If TABLE = 1000, go to HALT 
If not 1000, bump 

table by- 
five 
Bump XRl by -1 and go to 
next instruction (*+l) 
Store this number away 
Go back through the LOOP 
again 



HALT 



HTR 



Halt - end of job 



FIVE DEC 5 
TABLE DEC 3 . 9 



Set up consteint of 5 to in- 
crement the numbers . 
Set up a ntimber at random in 
location called TABLE. This 
will be zeroed out by first 
STZ instruction. 

In this case by using TXI and using -1, we are actually 
increasing the address of the STORE by 1. Since we started 
with zero, the program continues through the LOOP until 1000 
is reached, at which time it transfers to HALT, 

Note the connectorri) in the flow chart above. Connec- 
tors are used in flow cfiarting instead of crossing over 
lines. This is particularly necessary in large flow charts 
that cover more than one page or where there are a number 
of returns to earlier parts of the flow chart. 
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Lesson 8, (cont'd) 



solved may be complex enough to require more thaji one Index 
Register. The computer allows the programmer the capability 
of using two, or even three. Index Registers at the same 
time to do different jobs. 

For example, if we wished to move 50 sequential words 
located at A through A + 49, to location B through B + 49 
and we also wanted to move every tenth word to C through 
C + 4, this could be accomplished by setting up two Index 
Registers (one to make 50 moves and the other to pick up 
every tenth move). 

In the same manner, if the problem calls for three dif- 
ferent types of action at the same time, three Index Regis- 
ters may be used to control the action. 

Generally, Index Registers are used in the execution of 
a LOOP, where the program goes around and around the LOOP 
until that part of the job is finished. In using more than 
one Index Register, great care must be taken that the two 
(or three) loops do not interfere with each other and that 
each one does its own job. 

On the following pages, the simple example given above 
will be flow charted and programmed as an example of the 
use of two Index Registers. Follow it through carefully 
before attempting the problem on page 106. 
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Lesson 8, (cont'd) 

EXAMPLE ; 

Move 50 sequential words located at A through A + ^9 to 
location B through B + 49» Also move every tenth word to 
location C through C + k. Use XRl to make the 50 word move 
£md XR^ to pick up every tenth word. 

PLOW CHART 



MOVE TO 
LOC. C 



MODIFY 
XR4 



YES 




SETUP 
XRl AN0XR4 



MOVE A TO 

B MODIFIED 

BY XRl 




NO 



MODIFY 
XRl 



r HALT J 
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Lesson 8, (cont'd) 



PROGRAM 



LOG 



OP 



VARIABLE 



COUNT 19 
AXT 50, 1 
AXT 5, ^ 
LOOP CLA A + 50, 1 
STO B + 50, 1 



REMARKS 



'Set up XR's 

Move A into AC 
Store in loc, B 



CMPXRJ^ TXL MXR4, 1, kO 
TIX LOOP, 1, 1 
HTR * 



Moved 10 words? 
No, moved 50 words? 
Through - Halt 



MXR4 



STO 


C + 5, ^ 


CLA 


CNST 1 


SUB 


= 10B17 


STD 


CMPXR4 



STO 
TXI 



CNST 1 
CMPXR4 



+ 1, ^, -1 



Put 10th word into C 

Put kO into AC 

Subtract 10 

Changes kO to 30, etc. 
(by storing Decrement 
of AC to replace kO , 
etc . ) 

Save for next subtract 

Decrement XR4 



CNST 1 DEC 40B17 

A BSS 50 

B BSS 50 

C BSS 5 

END 



Constant for XRk in 
Deer, 



'Allocate storage to A, 
B, and C 
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Lesson 8, (cont'd) 

¥ORK AREA 

PROBLEM ; 

81, Expand the problem on page 10^ as follows: 

Move 50 sequential words located at A through 
A + 49 to location B through B + 49. Also move every fifth 
word to location C through C + 9 and every tenth word to 
location D through D + 4. Use XRl to malce the 50 word 
move, XR2 to pick up every fifth word and XRk to pick up 
every tenth word. 

FLOW CHART 
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Lesson 8, (cont'd) 

¥OKK AREA 
PROGRAM ; 

LOG OP VARIABLE REMARKS 
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Lesson 8, (cont'd) 



CORRECT ANSWER 



PROBLEM 81 ; 

FLOW CHART 




SETUPXRI, 

XRS.ANO 

XR4 



MOVE A TO 

B MODIREO 

BYXRI 



MODIFY 
XR2 



MOVE TO 
LOG. C 



YES 



YES 



MODIFY 
XR4 



MOVE TO 
LOC. D 



LOC 



OP 



VARIABLE 



REMARKS 



LOOP 



COUNT 
AXT 
AXT 
AXT 
CLA 
STO 




Set up XR«s 

Move A to AC 
Store in loc, Bs 



CMPXR2 TXL MXR2,1,45 moved 5 ifords? 





r HALT^ 



CMPXRU TXL 
TIX 

HTR 



MXR^,1,40 
LOOP, 1,1 



no, moved 10 words? 

no. 50 words, 

thxough? 

Halt - finished 



MXR2 



STO 
XCA 
CLA 
SUB 
STD 

STO 
XCA 
TXI 



C + 10,2 

CONST 1 

=5B17 
CMPXR2 

CONST 1 

CMPXR4, 2, 



Put 5th word in C 

Save AC in MQ 

Put k5 into AC 

Subtract 5 

This changes ^5 

to kOf etc. 

Save for next sub. 

Restore AC from MQ 

-1 

Decrement XR2 



KXRh STO D + 5, 4 

CLA CONST 2 

SUB =10B17 

STD CMPXR4 

STO CONST 2 

TXI CMPXR4 +1 



Put 10th word 

into D 

Put ^0 into AC 

Subtract 10 

This changes ifO to 

30, etc. 

Save for next sub. 

. ^, -1 
Decrement XRk 



CONST 1 DEC U5BI7 

CONST 2 DEC 40B17 

A BSS 50 

B BSS 50 

C BSS 10 

D BSS 5 
END 



Constant for XR2 
Constant for XRU 

Allocate storage 
to A, B, C and D 




MODIFY 
XRI 
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LESSON 9 

QUICK REFERENCE 

-t.m jx JVU v^x ■i-wi.-oJ i\^\u inxIfXIX iXLC<AlN.LiNU-0 

Refer to ~~~ 

Page No. 

1. MISCELLANEOUS INSTRUCTIONS 

47 XCA (+0131) EXCHANGE AC AND MQ - Reverses two 

fields 
30 HTR (+0000) HALT AND TRANSFER - Halts program, 

if restart, goes to Y, 
77 NOP (+0761) NO OPERATION - Program continues 

with next instruction. 

2. FIXED POINT ARITHMETIC INSTRUCTIONS 

27 ADD Uo400) ADD - Add Y to AC 

29 SUB (+0402j SUBTRACT - Subtract Y from AC 

29 MPY (+0200) MULTIPLY - Multiply Y by HQ, product 

in AC (and MQ if needed) 

69 RND (+0760-0010) ROUND - Increase AC by Binary 1 

if posit. 1 of MQ contains 1. 

29 DVH (+0220) DIVIDE OR HALT - AC and MQ are 

dividend, Y is Divisor, Quotient in 
MQ, remainder in AC. If can't 
divide. Halt. 

69 DVP (+0221) DIVIDE OR PROCEED - As above, ex- 
cept that if can't divide, continue 
with program with Div, check light 
on. 

69 DOT (+0760-0012) DIVIDE CHECK TEST - If indica- 
tor on, takes next instruction. If 
indicator off, skips one instr. 

3. FLOATING POINT ARITHMETIC INSTRUCTIONS 

k6 FAD (+0300) FLOATING ADD - Add Y to AC 

^6 FSB (+0302) FLOATING SUBTRACT - Subtract Y from 

AC 
h6 FMP (+0260) FLOATING MULTIPLY - Multiply Y by MQ 

k6 FDH (+0240) FLOATING DIVIDE OR HALT - AC divided 

by Y. Quotient in MQ, remainder in 
AC. If can't divide, HALT. 

4. SHIFTING INSTRUCTIONS 

47 ALS (+0767) AC LEFT SHIFT - The AC shift left 

no. position in Y 28-35. 
47 ARS (+0071) AC RIGHT SHIFT - As above, only 

shift to the right. 
73 LLS (+0763) LONG LEFT SHIFT - AC and MQ as one 

register, shifted left, no. places 

specified in Y 28-35. 
73 LRS (+0765) LONG RIGHT SHIFT - As above, only 

shift to the right. 
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Lesson 9, 

Refer to 
Pap,e No. 



(cont'd) 



27 
29 
30 
30 
73 

89 
89 
89 
89 



73 
31 

31 



^7 
kl 
77 

52 
53 

95 

95 
95 

95 

95 



5. STORE AI-JD LOAD D^TSTRUCTIONS ; 

CLA f+0500} CLEAR AND ADD - Move Y into AC 

STO (+0601) STORE - Move AC into Y 

LDQ (+O56O) LOAD MQ REGISTER - Move Y into MQ 

STQ (-0600) STORE FROM MQ REGISTER - Move MQ into Y 

STZ (+0600) STORE ZEROS - Move zeros into Y, sign 

to + 

STA (+0621) STORE ADDRESS -From AC to Y, 

STD (+0622) STORE DECREMENT-From AC. 



3-17 
STT (+0625) STORE TAG - From AC,q ^^ to 

STP (+0630) STORE PREFIX-From AC^ , „to 



21-35 
*° ^3-17 

^18-20 

Y 
S,l,2 



S,l,2' 

TRANSFER INSTRUCTIONS (NO INDEX) ; 

TRA (+0020) TRANSFER - Trans, to instr. spec, by Y 



TZE (+0100) TRANSFER ON ZERO - If AC = Zero trans- 
fer to Y Otherwise on to next instr, 

TOV (+01^0) TRANSFER ON OVERFLO¥-If AC overflow 

indicator on, treinsfer to Y, otherwise 
on to next instruction. 

TPL (+0120) TRANSFER ON PLUS - If sign of AC +, 
transfer to Y, otherwise to next instr. 

TMI (-0120) TRANSFER ON MINUS-If sign of AC-, 

trans, to Y, otherwise to next instr. 

CAS (+0340) COMPARE AC WITH Y-If c(AC)> c(y) go to 
next instr. If =, skip one instr. If 
< , skip two instr. 

NZT (-0520) STORAGE NOT ZERO TEST - If c(y) are 

not 0, skip instr. If c(y) are 0, on 
to next instr. 

ZET (+0520) STORAGE ZERO TEST - This is the op- 
posite of NZT instr. 

TRANSFER INSTRUCTIONS (INDEX ) ; 

TIX (+2000) TRANSFER ON INDEX-If c(XR)>Decr., XR 
reduced by Deer, and on to Y. Other- 
wise on to next instr, 

TXI (+1000) TRANS. WITH INDEX INCREMENTED - Adds 
Deer, to XR ajid on to Y 

TXL (-3000) TRANS. ON INDEX LOV OR EQUAL-If c(XR) 
<Cor = Deer, go to Y, otherwise on to 
next instr, 

TXH (+3000) TRANS. ON INDEX HIGH - If c(XR)> 

Decrement, go to Y, otherwise on to 
next instruction, 

TSX (+0074) TRANS. AND SET INDEX - Places 2's 
compl. of instruction CTR into XR, 
next instruction from loc, Y, 
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Lesson 9» (cont'd) 

Refer to 
Page No, 

8. INDEXING INSTRUCTIONS ; 

9h LXA (+0534) LOAD INDEX FROM ADDRESS - c(y) 

Moves into specified XR. 21-35 
9h LXD (-0534) LOAD INDEX PROM DECREMENT - c(y) 

Moves into specified XR. 3-17 
9h AXT (+077^) ADDRESSEE TO INDEX TRUE - Positions 

of this instruction, moves into ^1-35 

specified XR, 

9. PSEUDO OPERATION CODES ; 

60 COUNT - COUNT - First card of symbolic deck. Gives 

number of cards in program. 
60 END - END - Last card of symbolic deck. 
60 BSS - BLOCK STARTED BY SYMBOL - Allocates block of 

storage. First loc, of block tagged by a 

symbol, 
81 PZE - PLUS ZERO - Assigns one word and puts zeros 

into S, 1, 2, Can specify address, tag, 

decrement. 
81 EQU - EQUIVALENT - Used to define a symbol, 

81 OCT - OCTAL DATA - Data generating, series of 

variables, 

82 DEC — DECIMAL DATA — Data generating, decimal 

integers, fixed pt, or floating pt. 

REVIEV AND SELF-TEST 

The following pages touch on those areas with which the 
student should now be fgimiliar. Page references will be 
given with the correct answers and it is suggested that the 
reference be checked on all questions answered incorrectly. 

Consider this to be a self -administered, open book quiz. 
There will be 25 questions covering the first eight lessons 
and a problem to be flow-charted and coded. Answer all the 
questions and complete the coding before checking the 
correct answers. The correct answers to the 25 questions 
may be found on page 11 6 and the correct solution to the 
problem on pages II7 and 118. 

Subtract two points for each question missed (if half a 
question is missed, subtract one point) and subtract one 
point for each coding error from a total possible of 100, 
Total score on the two parts should be 70 or over and three 
hours is maximum time for the entire quiz. 

The quick reference of the kj instructions and 7 pseudo 
op. codes at the beginning of this lesson, is to aid the 
student in the quick recall of instructions. 
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Lesson 9f (cont'd) 



PROBLEMS 

83. Convert 759-, q *° Binary notation. 



8k, Add; 001 101 110 Oil 
+ 000 100 Oil 001 



85. a. Vhlch is considered greater by- the computer? 

circle one 



b. A Binary "one" in the 
sign position of a word 
indicates 



+ 



- 



86. In Division, the Quotient is always in the 

register. 

87. Show the Op. Code of STQ, as it would look in storage, 



I 2 3456789I0II 



88. a. Show a machine word containing the following 
fixed point ntimber: 

73^2.12313 



b. Indicate the position of the Binary point, 



89. Instructions 
CLA A 
SUB B 



Contents of A 
1278 

Contents of B^ 



Result 
in AC: 



36 



8 



90. a. Add: +35 Subtract: +35 Multiply: +35 
( + ) z21 (-) z21 (X) z21 



Sign of 
Result: 



Divide: +35 Quo, 
U) -39 









R 


em. 
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Lesson 9» (cont'd) 

91. Sh.ow the following in normalized form: 

a. 765»2o 



xxu 






c, ,uu<iyD 



10 



b. 22.16 



10 



xlO 



d. 100.011. 



92. Show the "characteristic" of the following floating 
po int numb er : 

CHAR. 



22 



10 



12 345678 
93 • Show the entire floating point word for the following 

Char. Meintissa 



niunber : 
32610 



9U. Add two fixed point ntimbers (A + b) , Move so that the 
Binary point in the AC will be between positions 9 and 10, 



OP 
CLA 

ADD 



VARIABLE 
A 
B 



JB0| 

(bo) 



95» The only instaruction allowing for a three-way branch, 
is 



96, In writing a program on a Symbolic Coding Sheet, the 

Loc. Code is placed starting in column , the Op. 

Code starts in column_ 
column 



and the Address in 



Comments may not extend beyond column_ 



97 • To indicate whether each of the following is an Element, 
Term or Expression, use the following s3rmbols. Element: 
E, Term: T, Expression: X. 



a. 500/7520 

b. TOTAL 

c. ALPHA * BETA 
98. TRA *+2 means: 



d. HOLD + A ♦ c 



I I e. ABZ * AB3/X 



f . A + B * C + X - Z 
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Lesson 9, (cont'd) 

99, HOLD PZE 15, 2, 27. Show the contents of storage loca- 
tion HOLD in Binary fonn( leave Sign and pos. 1 and 2 blank). 



^ 



100, Show the Octal representation of the following con- 
stants: 



a. DEC 26B26 

b. OCT 2211 

c. DEC ,003906B0 

d. DEC 7, 



101. Take the result of problem 99 and apply the following 
instructions : 



STA 
STD 
STT 



200 
300 
400 



Show the pertinent portions of the above locations 
after the instr*uctions have been executed. 



Q 



D 



200 300 400 

102, When an instruction contains a TAG, the address of the 
instruction is called the address. 



103, Index Register 2 looks like this: 

The instruction is; TIX A9, 2, 3» 

a. After instruction executed, 
how will XR2 look? 



0*- 



■♦0 I I 



b. ¥ill control go to A9 or to next instruction?, 

lOh, Contents of XRk 

Instruction: TXL HOLD, k, 124 

Control would be transferred to 



105, a. What do we put into an Index Register, to change the 
address of an instruction from 130 to 125? 

b. Which instruction is best used for this purpose? 



106, Instruction: STO ♦* 5 This means :_ 



107, ADD = 250 means: 
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Lesson 9» (cont'd) 
PROBLEM ; 

108. Given 10 floating point numbers located in AA 
through AA + 9. Given one floating point number located in 
BONE, The numbers that are greater than zero and alge- 
braically less than or equal to BONE, will be added together 
in location TOTAL and those that are greater them BONE will 
be added together in location HOLD. Ignore numbers less 
than or equal to zero. Flow chart before attempting to 
code the problem. 



LOG OP VARIABLE REMARKS 
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Lesson 9» (cont'd) 



CORRECT ANSWER 



PROBLEM 

8^. 759io = 13678 

= 001 oil 110 lll2(pg.ll) 



M- 15638 = 883j^Q 
04318 = 281^Q 

010 010 001 lOOgCpg. 12) 



8^. a. +0 (pg. 18j 
b. minus (-) (pg. 15j 



86. MQ 



(pg. 18) 



82. STQ (-0600) (pg. 23) 



00 I I 000000 

J__l I I I I I 1 — I 1 L 



88. 



(pg. 27) 



LoOOl 



OOOOOOOOIIIOIIIOOOIOOOIOIOOIIOOI 



40000734 24 I 231 

BINARY POINT 



82. 1278 = 87 
36q = 30 



10 



'8 



j^llO (pg. 28) 
57io= 7l8 



20. a.[=] b.[T] c.pq 



d. 



Q 
R 



(pgs. 27,29) 



21. a. .765 X 10-^2 

b. .2216 X 10 

c. .276 X 10" „ 

d. .100011 X 2-' 

(pg. ^1) 



22. 22^Q=268 = 010110. 2 
= .10110 X 2^(200+5=2058) 
^ CHAR. 



I 0000 I 01 

—I — I — 1 — 1 — I 1 — L. 



+ 2 



(pg. ^1) 



93. 326^^=5062=101000110.2 

= .10100011 X 2-'-l 
(200 + 11 = 211j^) 

CHAR. 







"8' 

MANTISSA 



lOOOIOOIIOIOOOIiO- 

_J 1 I 1 1 1 I 1 ■ 1 1 1 — I 1 — i— 1 L 



94 . |LRS 



6 

(pg. 7h) 



Ql 23 45 6 78 9 XX 

I 1 ■ 1 1 I I 1 1_4 L— L, 



95 . CAS 



(pg. 77) 



26. 1, 8, 16, 72 (pg. 59) 



22. 



a. T 

b. E 

c. T 



d. X 

e. T 

f. X 



(pg. 63) 



98 . Transfer to the second 
instr. beyond the 
"Transfer" instr, 

(pg. 63) 



22' 



15io=178 
Address 




^10=^8 
Tag 




27x0=338 
Decrement 





DECREMENT TAG 



ADDRESS 



0*- 



OIIOII 010 0-» 



-•►OOllif 



3 3 



I 7 

(pg. 81) 



100, a. +OOOOOOO32AOOO 

b. +000000002211 

c. +002000000000 

d. +203700000000 
(pg. 



83) 



101. 



R 



LOC.200 



►Ollll 



21 



D 



L0C.300 



35 



0**OII0lt 



D 



17 
L0C400 

010 

18-20 



(pg. 89) 
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Lesson 9» (cont'd) 



CORRECT ANS¥ER 



102. Presxoinptive (pg, 93) 



103. 
a. 







Oil 



b. A9 



(pg. 95) 



104. HOLD {XRk of 123 is less 
than Decrement of 1?^) . Re- 
member that all instmictions 
are written in Decimal iinless 
otherwise specified. 

(see page 96) 



105. a. 5 

b. AXT 



(pg. 96) 



106. store the contents of the 

AC into this location 

times 5. / ,^v 

(pg. 63) 



107. Add a constant of 250. 

(pg. 83) 




FLOW CHART OF PROBLEM 108 



CLEAR 

HOLD AND 

TOTAL AREAS 




117 



Lesson 9, (cont'd) 



PROBLEM 108 : 



CORRECT ANSWER 



LOG 



OP 



VARIABLE 



REMARKS 



COUNT 
START AXT 
STZ 
STZ 
CLA 
TPL 
TIX 
HTR 



22 

10, 1 

HOLD 

TOTAL 

AA + 10, 1 

CHICBI 

START + 3, 1» 1 



If zero, go to CHKBI 
Back to the CLA Instr. 



CHKBI 



CAS 
TRA 
TRA 
FAD 
STO 
TRA 



BONE 

ADDHI 

* + 1 

TOTAL 

TOTAL 

CIIKBI-2 



Compare with BONE 
(AC > 
(AC = 
(AC < 

Transfer to TIX instr, 



ADDHI 



FAD 
STO 
TRA 



HOLD 
HOLD 
CHKBI-2 



Transfer to TIX instr. 



BONE 


BSS 


1 


AA 


BSS 


10 


HOLD 


BSS 


1 


TOTAL 


BSS 
END 


1 



Allocate storage 
locations. 
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LESSON 10 

TAPE ; On pageviii.at the beginning of the book, several 
paragraphs were included on Data Channels and on tape. It 
may be worthwhile to review it at this time. There are a 
number of tenns used in connection with tape, that the be- 
ginner must familiarize himself with before he can start the 
study of tape hamdling. 

Proper handling of Input and Output is one of the most 
difficult areas to learn in programming. This course will 
not attempt to cover it in an exhaustive manner as only ex- 
perience can give the programmer a complete understanding of 
this topic. The major aspects and instructions will be 
covered — enough so that a general understanding will be 
gained by the student. 



REFLECTIVE SPOT ; A normal tape is about 2h00 feet long. It 
takes 6 to 8 feet on each end to wind on the tape drives. 
The tape has a little magnetic mark, called reflective spot , 
near the beginning. This is the Load Point of the tape 
(where Read or ¥rite will begin) , There is also a reflec - 
tive spot near the end of the tape , beyond which writing 
should not be done. Checking for the reflective spot at the 
end of the tape must be done by the program. 



TAPE MARK, END-OF-RECORD GAP, END-OF-FILE GAP ; At the bot- 
tom of the page is a symbolic representation of a tape 
which shows all of the areas named here, A tape record con- 
tains the same bits that we have been dealing with in com- 
puter storage except that they are stored on tape as mag- 
netic spots. Between the groups of magnetic spots are blemk 
areas of tape, approximately f inch wide. These are called 
end-of -record gaps. The gap after the last record on tape 
is called the end-of-file gap . This last gap and the tape 
raark. which precedes it, constitute the end-of-file and when 
this is reached, the tape may be rewound emd iinloaded from 
the tape drive. It must be understood that an end-of-file 
(designated by the tape mark) is a record just like any 
other record on tape. 



«-i- 8FT— * [ 



Total Length of Tape - 2^00 feet 



RECORD 
REFLECTIVE EOR 

SPOT GAP 

(LOAD POINT) 



^.^ |[^ ^ j 



EOF GAP 



(1 



-•— SFT* 

EOR I REFLECTIVE SPOT 
<5AP| (EOT POINT) 

TAPE MARK 
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Lesson 10, (cont'd) 

INPUT/OUTPUT INSTRUCTIONS AND COMMANDS 

1. MISCELLANEOUS 

RTD (read tape DECIMAL) Octal code: +0762. Channel (A 
through H) must be specified (i.e. RTDa). This instruction, 
followed by an RCH instruction causes the computer to read 
one record into storage. Reading will be accomplished from 
the Input/Output device specified in Y. The Channel must 
also be specified in Y. Tape density must be compatible. In 
other words, attempting to read a tape in one density, that 
was recorded in another density, will cause both detected 
ajid undetected errors. 

v;tD (^miTE TAPE decimal) Octal code: +O766. Channel (A 
through H) must be specified (i.e. ¥TDA) . This instiniction 
without the accompemying RCH instruction causes 3*75 inches 
of blank to be written. It is used to jump over a bad spot 
in the tape. With the RCH (page 121 ) , a normal record is 
written on tape. 



2. INPUT/OUTPUT OPERATIONS 

BSR (BACKSPACE RECORD) Octal code: +0764, This instruc- 
tion causes the tape, designated by Y, to back up until an 
end-of-record gap or load point is reached. It is used in 
the tape error routines. Chajonel (A-H) must be specified, 

VEF (write END-OP-PILE ) Octal code: +O77O. This instruc- 
tion causes the tape, designated by Y, to write an end-of- 
file gap and a tape mark, indicating the end-of-file (EOF) . 
Channel (A-H) must be specified. 

REW (rewind) Octal code: +0772. This instruction causes 
the tape, designated by Y, to rewind to the load point. At 
this time it is ready to be rtm again. Channel (A-H) must 
be specified. 



RUN (rewind and UNLOAD) Octal code: -0772. This instruc- 
tion causes the tape, designated by Y, to rewind to the load 
point and automatically set to be unloaded. Channel (A-H) 
must be specified. 



3. CONTROL INSTRUCTIONS 

TOO (transfer IP CHANNEL IN OPERATION) Octal code: +OO60. 
If the specified channel (A-H) is in operation, the com- 
puter takes its next instruction from location Y. If the 
chemnel is not in operation, the computer takes the next 
instruction in sequence. 
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Lesson 10, (cont'd) 

TRC (transfer on REDUNDANCY) Octal code: +0022 
The Channel yA-Uj must be specified. This concerns the in- 
ternal parity check. If parity is bad, an indicator turns 
on. The indicator is tested with this instruction. If the 
indicator is on, it is turned off and the computer takes its 
next instruction from Location Y. If the indicator is off, 
the computer takes the next instruction in sequence. 



TEP (transfer on END-OF-FILE) Octal code: +OO3O 
When the EOF gap is reached while reading, an indicator is 
turned on. This instnaction tests the indicator. If it is 
on, it is turned off and the computer takes its next in- 
struction from location Y. If it is off, the computer takes 
the next instruction in sequence. Channel (a-H) must be 
specified. 

h. CHANNEL INDICATORS ; 

BTT (BEGINNING-OF-TAPE TEST) Octal code: +O76O. 
Channel (a-h) must be specified. If there is a backspace 
(BSR) given when tape is at load point, em indicator turns 
on. This tests the indicator. If it is on, it is turned 
off and the computer takes the next instruction in sequence. 
If it is off, the computer skips one instruction. 

ETT (END-OF-TAPE TEST) Octal code: -O76O. 
Channel (a-H) must be specified. When end of tape is 
reached on writing, am indicator turns on. This tests the 
indicator. If it is on, it is turned of f and the computer 
tcikes the next instiniction in sequence. If it is off, the 
computer skips one instruction. 

5. INPUT/OUTPUT TRANSMISSION INSTRUCTION : 

RCH (reset and load channel) Octal code: +05U0 (for 
Channel A) . Channel (a through H) must be specified. This 
instniction must be given iimnediately following a Read Se- 
lect or a Write Select instruction, if transmission of data 
is to occur. The computer will not Read into storage or 
Write on tape unless the RCH instruction is present. 

6. DATA CHANNEL COMI-IANDS , 

lOCD (l/O UNDER COUNT CONTROL AND DISCONNECT) 
For input--this command will read the number of words speci- 
fied in the Decrement , beginning with the word specified by 
the Address. 

For output — outputs the number of words specified in the 
Decrement, beginning with the word specified by the Address. 
After completion, stops the execution of any other Chsuinel 
Command. 
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Lesson 10, (cont'd) 



lORT (input/output OF A RECORD AND TRANSFER) 
Input — always disconnects the Channel at the end of a record 
or when the count in the Decrement goes to zero (whichever 
comes first). 

Output — writes a record containing the number of words 
specified in Decrement portion of the Command, Starts to 
write from what is in the Address portion of the Command. 

If a Load Channel Command (LCH) is waiting, the next 
Command will be taken from the Address portion of the Load 
Channel, otherwise a normal disconnect occurs. 



READ TAPE ROUTINE 




ZERO 

CHECK 

COUNTER 



2 ^1 



READ 
THE TAPE 



WAIT 
UNTIL THRU 



RTDA 
RCHA 



TCOA 




HALT 
END-OF-JOB 



;) 



NCREASE 
CHECK CNTR. 
BY I 



ERROR ROUTINE 
9 



PROCESS 
RECORD 




L 



{ UNRE 



ALT > 

READABLE 
RECORD J 



ON WITH 
PROGRAM 
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Lesson 10, (cont'd) 

EXPLANATION 

An initial decision is made to try to read the tape ten 
times in the event of a bad piece of tape. There is aji in- 
ternal "bit" check (called parity check) which tells the 
computer if there is anything wrong with what it is reading. 

Block 1: A counter is set up at zero to keep track of 
reading until ten "reads" are reached. 

Block 2: A tape record is read by the computer. 

Block 3: No further processing until end-of-record is 
reached. 

Block k: Test for end-of-file. 

Block 5s If it is end-of-file, there is nothing more to 
be read, so the tape is rewound ajid unloaded. 

Block 6: Check for tape error (called parity check). 

Block 7s If there is no tape error, the prograun con- 
tinues with its normal processing of the record which is now 
located in computer storage. 

Block 8: If there is a tape error (called parity error), 
increase the Check Counter by one until a total of ten tries 
have been made to read the tape. 

Block 9: Check to see if the Counter is at 10, 

Block 10: If it is 10, halt the program. The record 
cannot be read by the computer. 

Block 11: If it is not 10, backspace the record and go 
back to Block 2, to try to read the same record again. 

Note the Input/Output Instructions associated with the 
various blocks. These are shown in greater detail for both 
Read emd Write operations on pages 126 and 12?, Channel A 
was arbitrarily chosen for the example. 

No instructions are designated for blocks 1, 5, 7, 8, 9, 
and 10 since these are not specifically input/output in- 
structions. 
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Lesson 10, (cont'd) 



¥RITE TAPE ROUTINE 




ZERO 

CHECK 

COUNTER 



WRITE 
A RECORD 



WTDA 
RCHA 




YES 



WRITE 
EOF 



8 



WEFA 



TELL THE 
OPERATOR 

TO LOAD 
NEW TAPE 



RUNA 





('halt ^ 
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Lesson 10, (cont'd) 



£^Ai'JL«Ar<AriUJN 



An initial decision is made to try to write five times 
in the event of a bad piece of tape. The parity check 
mentioned in the Read Tape Routine, also applies to write 
tape* 

Block 1: A counter is set up at zero to keep track of 
writing until five "writes" are reached. 

Block 2: A record is written on tape hy the computer. 

Block 3: No further processing lontil the writing of the 
record is completed. 

Block h: Test for tape error (parity error). 

Block 5: If no tape error, test for end-of-file. 

Block 6: If it is not end-of-file, the program continues 
with its normal processing. 

Block 7: If it is end-of-file, write end-of-file. 

Block 8: Rewind and unload this tape and if processing 
is not finished, have the operator load a new tape. 

Block 9: In Block 4, if there is a tape error, increase 
the check cotinter by one. 

Block 10: Test the Check Counter for 5. 

Block 11: If it is 5, write has been attempted five 
times without success. Stop the program. 

Block 12: If it is not 5, backspace the record. 

Blocks 13 and ihi Erase the tape, turn off the tape 
error (parity) light aad try to write the record again. 
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Lesson 10, (cont'd) 

EXAMPLE ; Read tape vinit h on Channel A, Process the data 
and write out on Channel C, tape unit 1, Stop when end of 
file (eof) is reached, (See note at bottom of the page.) 



LOG 



OP 



VARIABLE FIELD REMARKS 



(See X 
Note) 

Y 



TAPENO a4B, 



TAPENO CIB 



Defines X as Chan, A, 
unit k. Binary 
Defines Y as Chan, C, 
unit 1 t Binary 



READ 



STZ 



CTX 



TCOX 
RTDX 


* 


RCHX 
TCOX 


lOIN 
* 


(End of 

Read Routine) TEFX 


EOF 


TRCX 


PEX 



Store zeros in Read 

counter 

Wait 

Read Chan, A, unit k, 

Binary 

Reset and load Chan, A 

Wait until record is 

read 

If it is End-of-File, 
go to EOF 

If there is Parity 
Error, go to PEX 



Process record and place output into AREA 1 



WRITE STZ 



CTY 



TCOY 


* 


WTDY 




RCHY 


lOOUT 


TCOY 


* 



TRCY 



PEY 



(End of 

Write 

Routine) 



TRA 


EOF 


TRA 


READ 



Store zeros in Write 

Counter 

Wait 

Write a record 

from Area 1 

Wait until through 

writing 

If there is parity 

error, go to PEY 

Is it End-of-Tape? 

If End-of-Tape, go to 

EOF 

If not End-of-Tape, go 

back to read next 

record 



Note that at the beginning of the program, the Op, Code 
TAPENO, with a one character location code was used to de- 
fine the Chsuinel, Tape Unit, and type of notation (Binary), 
This is much simpler than using the actual channels (A 
through H) on each succeeding instrxiction. Also notice how 
easily the counter is increased and checked with the use of 
literals in the error routines on the next page. 
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Lesson 10, (cont'd) 



EXAMPLE — continued 



LOG 



OP 



VARIABLE FIELD REMARKS 



CTX 
CTY 

lOIN 



AREA 
EOF 



PZE 
PZE 
lORT 



BSS 
HTR 



AREA, , 100 



100 



Define CTX (X counter] 
Define CTY (y counter] 
Channel Command for 
input. Decrement of 
100 (chosen arbitrarily) 
Allocate 100 positions 
for AREA 
Halt - end-of-job 



Pick up loose ends 



PEX 
(Error rou- 
tine for 
Read) 



CLA 
ADD 
STO 

SUB 

TZE 

BSRX 
TRA 



CTX 
= 1 
CTX 

= 10 

EOF 



READ + 1 



Increase counter by 1 



To check if counter 
equals 10 

If 10 tries, go to EOF 
to halt program. Un- 
readable tape 
If not 10 tries, back- 
space record 
Go back to READ + 1 ajid 
try again 



lOOUT 10 CD 
AREA 1 BSS 



AREA 1, , 45 
h5 



Outputs number of words 
specified in Decrement 
Allocate 45 storage po- 
sitions to AREA 1 
(again arbitrarily 
chosen) 



PEY CLA CTY 

(Error ADD = 1 

routine for STO CTY 

Write) SUB = 5 

TZE EOF 



BSRY 

WPTW 




W iDl 
TCOY 


* 


TRCY 


* 


TRA 


WRITE + 1 



Increase counter by 1 

To check if counter 
equals 5 

Unwriteable tape, go 
to EOF 
Back up and erase tape 

Wait 

Turn off parity light 
Go back to WRITE + 1, 
and try again. 
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Lesson 10, (cont'd) 

BUFFERING ; A buffer is not a separate piece of equipment. 
It is an area of storage, assigned by the programmer, 
specifically to accept Input/Output infoxroation. 

The Read and Iv'rite routines shown on pages 122 and 12U, 
do not show how this is accomplished with Buffering . In 
some instances, using the buffering technique speeds up the 
procedure considerably since one recprd may be processed at 
the same time that smother is being read. 

This technique is not shown here because most installa- 
tions now have ready-made Input/Output Packages which do 
the job of reading and writing in the most optimum manner. 
Where the Package is available , it should be used in 
preference to writing individual Input/Output routines, 

input/output PACKAGE ; Most organizations have prepared 
Input/Output programs which may be utilized in conjunction 
with nearly all normal programs. This saves considerable 
time in programming because usually a great deal of the 
progretmming effort deals with Input and Output processing. 

The new programmer must familiarize himself with the 
Input/Output Package of his organization and merely tie it 
in to his own program. 

The preceding pages , dealing with Input and Output 
routines, were important primarily so that the new pro- 
grammer would have a working understanding of what occurs 
during Read and Write operations. Also, there are occasions 
when Input/Output Packages are not available and therefore 
Input and Output must be programmed along with the basic 
problem. 
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Lesson 10, (cont'd) 

WORK AREA 

PROBLEM ; 

109. Read tape unit 8 on Channel E. Place the first 
word of the record into storage at loc. HOLD, go back emd 
read another record, placing the first word into HOLD + 1, 
Halt when end-of-file is reached. 
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Lesson 10, (cont'd) 



PROBLEM 109 ; 

LOG OP 



CORRECT ANSWER 



VARIABLE FIELD REMARKS 



Z TAPENO 

READ STZ 

RTDZ 
RCHZ 
TCOZ 

TEFZ 



E8B 
COUNT 

IOC 

♦ 

EOF 



TRCZ 


PE 


CLA 


IOC 


ADD 


= 1 


STO 


IOC 



TRA 



READ 



Defining tape tinit 8, 
Chan. E, Binary 
Store zeros into 
counter 

Read first word of 
one record. 
Wait until record is 
read 

If we have reached end 
of file, go to EOF. 
If tape error, go to PE 
Increase location by- 
one to store the one 
word for the next 
record to come in. 
Go back to beginning to 
read next record. 



PE 



CLA 


COUNT 


ADD 


= 1 


STO 


COUNT 


SUB 


= 10 



TZE 

BSRZ 
TRA 



BT 



READ + 1 



IOC lORT 



HOLD BSS 



HOLD, , 1 



1000 



Move counter into AC 
Add 1 

Place back into storage 
Check to see if counter 
has gone to 10 (if so, 
indicates bad tape) . 
If tried to read 10 
times, bad tape. Go to 
BT (which is equivalent 
to EOF) 

If not yet 10 tries, 
backspace the record. 
Go back to try reading 
the record again. 



COUNT 


BSS 


1 


Allocate one storage 
position to counter. 


EOF 


HTR 


* 


End of file. Halt prog. 


BT 


EQU 


EOF 


Define that BT is equi- 
valent to EOF 



I/O command to read 
first word of each 
record. 
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Lesson 10, (cont'd) 

¥OHK AREA 
PROBLEM: 



110. Take the data from loc. HOLD, HOLD + 1, HOLD + 2, 
etc., and write it out on Channel H, tape unit 3. When 
HOLD + 999 is reached, i«*ite EOF and stop the program. 

LOC OP VARIABLE FIELD REMARKS 
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Lesson 10, (cont'd) 

PROBLEM 110 ; 

LOG OP 



X 



TAPENO 
STZ 



CORRECT ANSWER 

VARIABLE FIELD REMA.RKS 

H3B Defining tape 3, Chan. 



LOOP WTDX 
RCHX 
TCOX 

TRCX 

STZ 



CT 

10 
* 

PE 
CT 



H , Binary 

Stores zeros into 

counter 

Write a record 

Wait until through 
writing 

If there is parity- 
error, go to PE 
If no paxity error, 
zero counter 



10 
CT 



LOOP 


1 WEFX 




Write end-of-file 


(End-of- 


TCOX 


* 


Wait imtil write is 


file 






finished 


routine) 


TRCX 


PEl 


If parity error for EOF, 
go to PEl 


BT 


HTR 


* 


Bad tape - Halt 


PE 


CLA 


CT 


Move counter into AC 




ADD 


= 1 


Add 1 




STO 


CT 


Put back into storage 




SUB 


= 5 


Have we tried 5 times? 


(parity 


TZE 


BT 


If yes , go to BT to Halt 


error 


BSRX 




If no, backspace record 


routine) 


WTDX 




Erase tape 




TCOX 


♦ 


Wait until through 




TRCX 


* 


Turn off parity light 




TRA 


LOOP 


Go back to try to 
write again 


PEl 


CLA 


CT 






ADD 


= 1 




(parity 


STO 


CT 




error 


SUB 


= 5 




routine 


TZE 


BT 




for EOF) 


BSRX 
WTDX 








TCOX 


♦ 






TRA 


LOOP 1 





lOCD 



PZE 



HOLD , , 100 



Outputs no, of words 
specified in Deer. (lOO) 
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LESSON 11 

SUBROUTINES ; In nearly all program writing it becomes 
necessary to repeat certain program steps. It is usually 
not desirable to write these steps over and over as the 
need arises. It is much more practical to write the steps 
once and then arrange to jump to this group of steps when 
necessary. A subroutine is essentially just this— a group 
of program steps which may be used repeatedly as required. 

There are two types of subroutines: Open and Closed. 
The Open subroutine is inserted into the main program emd 
the Closed subroutine is separate and apart from the main 
program. The Closed subroutine is the most economical and 
the most commonly used, but it is difficult to instmact the 
subroutine as to where in the main program it should retuni 
when it is finished processing. The process used is 
subroutine linkage . 

SUBROUTINE LINKAGE ; There are several ways of linking a 
subroutine to the main program. One of the most simple and 
economical is to use Index Registers to provide a path to 
amd from the main program. This has the added adveuitage 
that the programmer need not be aware of the actual address 
of the return jump and may continue to write his program 
in symbolic . Some of the other linkage methods require the 
knowledge of the actual address for the return jump to the 
main program. An example of subroutine linkage may be 
foxind on the following page. 

Symbolically represented, subroutine linkage would look 
like this: 



Main Program 



Jump to Subr, 1 



Jump to Subr. 



Jtunp to Subr, 



Jump to Subr. 2 




— — ^"^RETURN ^"'"-'^^ 



Subroutine 2 



--^Return 
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Lesson 11, (cont'd) 

EXAMPLE 1 ; Suppose that it was necessary to sum three 
variables auad leave the sum in a fourth variable emd it was 
necessary to do this for many different sets of variables. 
A portion of the program could be: 

I see Lesson 8 for explanation of TSX) 
1st variable] 
2nd variable, 
3rd variable, 
answer) 

If the prograjn were as above, the subroutine could be: 

SUM 



TSX 


SUM, k 


PZE 


A 


PZE 


B 


PZE 


C 


PZE 


D 


program were 


CLA* 


1, ^ 


FAD* 


2, h 


FAD* 


3, h 


STO* 


k, k 


TRA 


5, h 



The asterisk (*) after the Op. Code means that the 
instruction is indirectly addressed. Detailed explanation 
of this technique ajid additional examples may be found in 
Lesson 12, It may be worth while delaying the detailed 
study of this excunple until Indirect Addressing has been 
covered in Lesson 12, 

EXAMPLE 2- : Let us suppose that there is a long progrsun, 
with a number of parts, each going to a particular subrou- 
tine, ajid from there back to the beginning of the loop. The 
flow chart below shows such a program. (This is the flow 
chart for the program on the following page. It is not 
truly a closed subroutine , but it does show how a program 
can be manipulated with Index Registers.) 

Notice that on each test for trsmsfer, if the condition 
is minus, the program goes to an interchemge routine and 
from there back to the beginning of the loop. This may be 
graphically represented as follows: 

PROGRAM 

LOOP CLA 

First part of loop. Trans f. on + to 
next part. If not +, go to subr. INTER 
TPL N02 
TRA INTER 
N02 - ^ Second part. TPL to next part or go to 

subr. 
TPL NO 3 
TRA INTER 

N03 - ' Third part. TPL to next part or go to 

- \ subr. 

TPL HOk f 
TRA INTER 
N04 - Fourth part. Finish program, 

HTR * 
INTER - Subroutine, Always goes back to start 

TRA LOOP of LOOP 
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Lesson 11, (cont'd) 



(START) 






START 
LOOP 



CLA 



SUB2 



(hf2) 




TO DETERMINE 
*WHICH IS 
LARGEST 



INTERCHANGE 
C(l) ac(2) 



(1^2) 


CLA2 


^ * 




♦ 




SUB3 



(2<:3) 




SUB 4 



INTERCHANGE 
C(2)aC(3) 



CLA 3 



(3<4) 



INTERCHANGE 
C(3) aC(4) 




TRANSFER 
FIELDS 1-4 

TO 
HOLD! -4 



G 



ALT 



) 



WORK AREA 

PROBLEM 111 . Given fixed point integers, located sequen- 
tially in Field 1, Field 2, Field 3 and Field 4, Sort so 
that the largest value will go into location HOLD, next 
largest in HOLD + 1, etc. 



LOG 



OP 



VARIABLE 



LOG 



OP 



VARIABLE 
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Lesson 11, (cont'd) 



CORRECT ANSWER 



PROBLEM 111. 
















LOG 


OP 


VARIABLE 




REMARKS 








COUNT 


32- 










LOOP 


AXT 


0, 1 














CLA 


FIET.n, 


1 




Start of LOOP 






TXI 


* + 1, 


1, 


-1 


Compare 1 and 2 






SUB 


FUiiLD, 


1 




(XRl = -1) 








TPL 


2VS3 






If 1 > 2 , go 


to 


2VS3 




TRA 


INTER 






If K 2 , go 


to 


subr. 


2VS3 


CLA 


FIELD, 


1 




(XRl = -1) 








TXI 


* + 1, 


1, 


-1 


Compare 2 and 3 






SUB 


FIELD, 


1 




(XRl = -2) 








TPL 


3VS^ 






If 2>3, go 


to 


3VS4 




TRA 


INTER 






If 2<3, go 


to 


subr. 


3VS4 


CLA 


FIELD , 


1 




(XRl = -2) 








TXI 


* + 1, 


1, 


-1 


Set XR for k 








SUB 


FUETrD, 


1 




(XRl = -3) 








TPL 


MOVE 






If 3 >^, go 


to 


MOVE 




TRA 


INTER 






If 3 < 4 , go 


to 


subr . 


MOVE 


AXT 


^. 2 






\ 








CLA 


FIELD + 4, 


2 


>Move to HOLD 


area 




STO 


HOLD + 


4. 


2 


/ 








TIX 


* -2, 2, 1 




Small loop back 


to CLA 



HTR 



until all k numbers 

are moved. 

Halt - end of job. 



INTER CLA 
(Sub- TXI 

routine) LDQ 
STO 
TXI 
STQ 
TRA 



FIELD, 1 

* + 1, 1, 1 
FIELD, 1 
FIELD, 1 

* + 1, 1, -1 
FIELD, 1 
LOOP 



I Exchange - last cell 
)> defined by XRl with 
previous cell (word) 



/* 



Back to start of LOOP 



FIELD BSS k 
HOLD BSS k 
END 
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Lesson 11, (cont'd) 



LOGICAL OPERATIONS ; Logical operations have a special way 
of operating on a 36 bit word. They are used primarily for 
masking operations, which are discussed on page l40. The 
sign position is simply another bit amd is not considered 
separately from the other 35 bits in the word. 

SpeciaJL rules apply when two numbers are combined by 
logical instructions ♦ These rules are as follows: 



Ones in both numbers equal 



one 




1, Logical AND operations; 
Otherwise zero. 

Example; 001011 

001101 

= 001001 



2, Logical OR operations; A one in either number 
causes a one in result. Otherwise zero. 

Example; 001011 

001101 

= 001111 



3. Exclusive OR operations: A one in only one of the 
numbers equals one. Otherwise zero. 




Example : 



001011 
001101 
000110 




In logical operations, when two numbers are combined, 
they are matched bit for bit as shown in the examples 
above. Notice the differences in the resultemt numbers. 
Converting the Binary numbers above to Octal: 



AND op. 



13 
11 

= 11 



8 



OR op. 



13 
11 

= 17 



8 



Excl. OR op. 



13 
11 

= 6 



8 



Do not confuse logical operations with the noxmal 
arithmetic operations. 
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Lesson 11, (cont'd) 

INSTRUCTION ; CAL (Clear and Add Logical Word) Octal code: 
FORMAT ; (Type B) -O50O 



OPCODE 


lA 


W//, 


TAG 


Y 



S,l 1112-13 18-2021 35 

DESCRIPTION : This is identical to the CLA (Clear and Add) 
instruction except that the sign goes into the P position! 
of the AC. 



INSTRUCTION ; SL¥ (Store Logical Word) Octal code: +0602 
FORMAT ; (Type B) 



OPCODE 


lA 


VM 


TAG 


Y 



S,l 



1112-13 



18-2021 



35 



DESCRIPTION ; This is identical to the STO (store) instruc- 
tion except that the bit in position P of the AC goes into 
the sign position of the word. 



INSTRUCTION ; ANA (AND to Accumulator) Octal code: -0320 
FORMA.T: (Type B) 



OPCODE 


lA 


vm 


TAG 


Y 



S.l 



1112-13 



18-2021 



35 



DESCRIPTION ; Each bit of the c(y) is matched, with the cor- 
responding bit in the c(AC) (positions P, 1-35). The result 
of the matching (using the rules laid down in page 137) will 
be in the AC. AC positions S, Q are set to zero. 



INSTRUCTION ; ANS (AND to STORAGE) Octal code; +0320 
FORMAT; (Type B) 



OP CODE 



lA 



TAG 



S,l 



1112-13 



18-2021 



35 



DESCRIPTION : Each bit of the c(AC) (positions P, 1-35) is 
matched with the corresponding bit in the c(y). The result 
will be in storage at location Y. 



EXAMPLES I 



BEFORE 







AC 




ll 





1 


1 


Y 


|i 


1 


1 


s\ 



INSTRUCTION 
ANA 

ANS 



AFTER 













ll 








1 


o| 




ll 








1 






in AC 



in Y 
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Lesson 11, (contVd) 



INSTRUCTION ; ORA (OR to Accumulator) Octal code: -O5OI 






OP CODE 



lA 



TAG 



S,l 



1112-13 



18-2021 



35 



DESCRIPTION S Each bit of the c(y) is matched with the cor- 
responding bit in the c(ac) (P, 1-35). The result (using 
the rules on page 137) will be in the AC. The c(y) and the 
S and Q positions of the AC remain unchanged. The sign of 
Y will be in the P position in the AC. 



INSTRUCTION ; ORS (OR to STORAGE) Octal code; -0602 
FORMAT ; (Type B) 



OP CODE 




lA v///A-^^<^ 



s,i 



1112-13 



18- 2021 



35 



DESCRIPTION ; As above, except that the result will be in 
the c(Y) smd the bit in position P of the AC will be in the 
sign position of Y. 



INSTRUCTION ; ERA (Exclusive OR to Accumulator) Octal code: 
FORMAT ; (Type B) +0322 



OPCODE 


lA 


W/a 


TAG 


Y 



S,l 



1112-13 



18- 2021 



35 



DESCRIPTION ; Exactly the same as the ORA instructions 
above, except that the rules for ERA apply (as shown on 
page 137). 



EXAMPLES 1 



BEFORE 





AC 






1 





1 


1 


Y 


1 


1 


1 






INSTRUCTION 

ORA 
ORS 

ERA 



AFTER 



1 1 1 11 in AC 
1 1 1 f) in Y 



10 1 in AC 
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Lesson 11, (cont'd) 

MASKING - PACKING AND UNPACICING ; Quite often, the items to 
be used in a computer operation are small enough, that more 
than one could fit into a machine word. This process is 
called packing . For example , if the numbers are no larger 
than three Decimal digits, they would convert to no larger 
than four Octal digits and three such numbers (complete with 
sign) could be placed into one machine word. 

XI X2 X3 



4- OCTAL 


4 OCTAL 


4 OCTAL 



S.l 



1112 



2324 



35 



In this example, the signs would be in positions S, 12 and 
24. 

Packing a word in this manner, not only saves storage 
space, but also speeds up machine operating time since it 
takes less time for the computer to read or write the data. 

If it is necessary to operate on one of the numbers 
packed into a word, it is necessary to mask out the other 
numbers. The mask may be set up by using the OCT pseudo 
op. code, 

EXAMPLE ; Two numbers are packed into a word as follows: 

location HOLD: 



Al 



A2 



S,l 89 35 

A2 is needed for other work. Mask out Al(this is unpacking) 



LOC 



OP 



VARIABLE FIELD 



REMARKS 



CAL 


HOLD 


ANA 


MASK 


ALS 


9 


SLW 


A2 



MASK OCT 000777777777 



Move word into AC 
Add logical-MASK (de- 
fined below) 
Left shift to bring A2 
into proper place in AC 
Store from AC into 
loc. A2 

This will put 9 zeros 
into S-8 and 27 ones 
into 9-35 of the Mask 
word (Using AND rules- 
zeros will blank out 
the word while ones 
will have no effect). 



Assume that Al = 123g and A2 = 323323323g 



AC before MASK: 



AC after MASK: 
(using AND miles) 



6 






OIOIOOII 


01 101 001 101 1 1001 101 1 01 00 1 1 



V_89^ N^ ^-/ V^ V_^ ^-^ N_^ S«^ V^5 

33233233 2 3 



00000000 



on 0100 1 loiioiooiioiioiooii 



I 89 

BLANKED OUT' 



35 



3 2 3 



3 2 3 3 2 3 

NO CHANGE 
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Lesson 11, (cont'd) 
EXAMPLES continued ; 

Three numbers are packed into a word as follows: 
location STAND: 



XI 



S.I 



X2 



89 



X3 



Mask out X2 and move Z2 



position, 
LOC OP 



Z2 



1718 3! 
into the vacated X2 



S,l 8 
VARIABLE FIELD REMARKS 



MASK 



GAL 

ANS 



CAL 
ARS 

ORS 
OCT 



MASK 
STAND 



Z2 
9 



STAND 
777000777777 



Place MASK into AC 
Match MASK, bit for bit with 
c( STAND). This blanks out 
X2 in storage. 
Move Z2 into AC 
Shift rigjit 9 positions to 
line up with positions 9-17 
OR to storage loc, STAND 
Sign ajid 1-8 will be ones, 
9-17 will be zeros and 18-35 
will be ones (Using OR rules 
- zeros will have no affect 
on the word while ones will 
blank out the word ) , 



Assume that X2 = 123o and Z2 = 456 



8 



Before execution of ANS instr. LL 
(Mask in AC) 



1 1 1 1 1 I II 



000000000 



nil 1 1 i II 1 1 1 11 II N 



77700 07777 77 



XI, X2, X3 in loc, STAND: 



After execution of ANS instr, 
(contents of loc. STAND) 



R 



001 01 00 1 I 



89 



X3 



1718 



35 



NO 



□ CHAN GE BLANKED OUT 
XI 



NO CHANGE 



000000000 



X3 



89 



1718 



35 



Before execution of ORS instr. f" 
(Z2 now in the AC) "— ' 



I 001 Oil! 



X3 



8 9 1718 

4 5 6 
Z2 



3 



35 



lOOIOI I I 



X3 



89 



1718 



After execution of ORS instr. FT 

(Z2 moves intact into loc. I ^' 
STAND) I 

4 5 6 
The zeros in loc, STAND are compared to k^Sg in the AC. 
Using the rules for OR, the k^Sg in the AC moves intact 
into loc. STAND and the job is finished. 
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Lesson. 11, (cont'd) 

EXAMPLES continued ; 

XI, X2, and X3 are to be packed into location HOLD. 
XI = 2222g X2 = 33338 X3 = kkkk^ 

Before packing: 

xi q 
x2q— 



01 001 001 0010 



24 



35 



X3q: 



01 I 01 I 1 101 I 
?4-^ 



35 



I 001 001 001 00 



LOG 



OP 



24 35 

VARIABLE FIELD REMARICS 



CAL 


XI 


ALS 


12 


ORA 


X2 


ALS 


12 


ORA 


X3 


SL¥ 


HOLD 


HTR 


♦ 



AC = 



Ti<rn 



XI 



JxT 



X2 



XI 



X2 



XI X2 X3 



Store from AC into loc. HOLD 
Halt - end of job 



INSTRUCTION: LGR (Logical Right Shift) Octal code: -O765 
FORMAT : (Type B) 



OPCODE lA ;s:^^ TAG I Y 



S,l 



1112-13 



18-2021 



35 



DESCRIPTION : The contents of the AC and MQ are treated as 
one long register (this includes the S,Q,P in the AC, and 
the S in the MQ) , The contents are shifted to the right the 
number of places specified in positions 28-35 of (y) the 
address portion of the instruction, Thesign 'of the AC 
will remain unchanged. 



INSTRUCTION ; LGL (Logical Left Shift) Octal code; 
FORMAT : (Type B) 



-0763 



OP CODE 



lA 



TAG 



S.I 



1112-13 



18-2021 



35 



DESCRIPTION : Identical to the LGR instruction, except that 
the shift is to the left. In both of the above instruc- 
tions, vacated positions are filled with zeros. Any bits 
shifted left of position Q in the AC, will be lost. 
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Lesson 11^ (cont'd) 

EXAMPLES ; 

1, The exEimple shown on page 1^2 may also be accomplished 
with the IXJR instruction. 



XI = 
X2 = 
X3 = 
LOC OP 



XI 1 


24 


35 


1 X2 1 


24 


35 


X3 



24 
VARIABLE FIELD 



35 



Store in loc. HOLD. 
REMARKS 



AC 



CAL 

LGR 

CAL 

LGR 

CAL 

LGR 

STQ 
HTR 



X3 

12 

X2 

12 

XI 

12 

HOLD 
* 



MQ 



X3 



X3 I 



mn 



UTT 



: 



U^ 1X3 I I 



Tin— I 



1X2 1X3 



J 



IXI 1X2 1X3 I 



Store from MQ into loc, HOLD 
Halt - end of job 



2. 



XI = 1 XI 


1 




1 


S,l 


II 






X2 = 1 


1 X2 


1 


1 




12 


23 




X3 = 1 X3 


1 




1 



LOC 



S,l II 
OP VARIABLE FIELD 



Store in loc. HOLD. 



REMARKS 



AC 



MQ 



CAL 


X3 


ARS 


2k 


LGR 


12 


CAL 


X2 


ARS 


12 


LGR 


12 


CAL 


XI 


ARS 


2k 


LGR 


12 


STQ 


Hold 



X3 



X3 



X2 



X2 



XI 



Hl 



1 




1 ! 




1X3 1 1 




1X3 1 1 




1X3 1 1 




1X2 1X3 1 1 




|X2 1X3 1 1 




X2 1X3 1 1 




1 X 1 1 X2 1 X3 1 



Store from MQ into loc. HOLD 
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Lesson 11, (cont'd) 



A Mask may be used very effectively to change instruc- 
tions. This process is a little tricky at first, because 
the bits must be shuffled to do the required job, 

EXAMPLE ; 

1, We wish to use a Mask to change the following instinic- 
tion: 



LOG 



OP 



VAR. 



ABC 



STO HOLD 



to 



LOC 



OP 



VAR. 



ABC SLW 



HOLD 



In this case, only the op. code is to be changed: 

From: STO = +O6OI 
To: SLW = +0602 

A mask may be set up with the pseudo op» OCT or with a 
literal (see page 83). The following instructions will do 
the job. 



LOC 



OP 



VARIABLE FIELD 



REMARKS 



CAL =0000200000000 



STORAGE CONTAINS 



000 



I 10 



00q00l|-- ORS ABC 



CAL =0777677777777 



ANS 



ABC 



into AC 

|00 0|0 00|000|0I 0|- » 

2 
into stor. 

|000|l I 0|000|OI l|— - 
6 3 

into AC 

|l I l|l I l|l I l[l I Oj^ 

7 7 7 6 
into stor. 

OOOll I oloooloi 0|- - 



6 2 
2. Change FAD (+O300) , located in AA, to ANS (+O320) 



LOC 



OP 



VARIABLE FIELD 



REMARKS 



CAL =0002000000000 



STORAGE CONTAINS 
jOOOlOl l|000|000|-* -ORS AA 



into AC 

looopoqoi o|ooq- 
0020 



into storage 

° ^ ° ° |000|0I l|OI 0|000|- 

3 2 
The Octal 2 in the mask simply drops into place to re- 
place the Octal zero. Many people find it easier to think 
in Octal rather than in Binary when preparing a mask. 
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Lesson 11, (cont'd) 

PROBLEMS ; 

112. Pack XI, X2 and X3 into loc. HOLD. 

XI = I XI I 1 

s] ii 



X2 = xF 



12 23 
X3 = I X3 I 



S,l 11 

This is the same as example 2 on page 1^3, but in this 

problem, work from the MQ into the AC, using left shifts, 

LOC OP VARIABLE FIELD REMARKS 



113. Use a mask to change the following instructions: 

ZZ CLA XYZ to ZZ GAL XYZ 
(+0500) (-0500) 

LOC OP VARIABLE FIELD REMARKS 



114. At the completion of problem 112, XI, X2 and X3 
are packed in loc. HOLD. Unpack X2 and place it into loc 
STAND, in orig. position, 

LOC OP VARIABLE FIELD REMARKS 
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Lesson 11, (cont'd) 



PROBLEM 112 . 
LOG OP 



TEMP 



LDQ 

LGL 

LDQ 

SLW 

LGL 

CAL 

LGL 

LDQ 

LGL 

SLW 
HTR 
BSS 



PROBLEM 113 * 
LOC OP 



CORRECT ANSWERS 



VARIABLE FIELD 



REMARKS 



XI 

12 

X2 

TEMP 

12 

TEMP 

12 

X3 

12 

HOLD 

* 

1 





AC 




1 1 




1 Ixi 1 




XI 1 


save AC 


in 1 


1 1 




1 Ui 1 




1 


Xi 


X2 




1 


XI 


X2 




Ixi 


X2 


X3 1 



[xrr 



MQ 



TxFT 



rx2T 



rx2 



1X3 



Store into loc, HOLD 
Halt - end of job 
Allocate storage posit, to 
TEMP 



VARIABLE FIELD 



REMARKS 



CAL =^400000000000 
ORS ZZ 



The Octal k will put a one bit into the sign position, 
changing the + to a -. 



PROBLEM 114. 



LOC 



OP 



VARIABLE FIELD 



CAL HOLD 

ANA =0000077770000 



SLW STAND 



REMARKS 



Move HOLD into AC 
Literal - the 7's will 
all be ones. This will 
leave X2 , while masking 
out XI and X3. 
Store into loc, STAND 
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LESSON 12 

SENSE INDICATOR OPERATIONS ; Before going into this area, 
turn back to page 1? and review subparagraph 2 on Sense"' 
Indicator Registers. 

There are two types of switches on the 709O: (l) Sense 
Switches, which are located on the computer console, and 
are manipulated by the operators and (2) Sense Indicators . 
which are internal to the machine and are manipulated by 
the program. 

There are six Sense Switches . The pseudo op. SWT (page 
148) tests the setting of any switch. A group of sense 
indicator instructions are used to manipulate and test the 
sense indicators . 

Each of the 36 bits in the Sense Indicator Register (SI 
Register) may be used as a switch or bits may be used in 
groups. They are ttirned on when the bits are set to "one" 
and off when set to "zero." The bits are manipulated by 
the programmer by the use of a Mask (see page l4o). 



Sense switches may be compared to switches on a rail- 
road. In a railroad operation, it is known that at certain 
points along the track, the train must switch to either one 
of two branches depending on certain conditions that occior 
at the time the train reaches the switch or at some pre- 
vious point in time. In the same manner, at the time a 
program is being written, it may be known that conditions 
will arise which will require that the program proceed 
along one of two branches at a later point. 

At the point where the decision is to be made as to 
which branch to be taken, an instruction is used to test 
the sense switch. This is also true of sense lights 
(covered on page 152). 



A few of the most valuable Sense Indicator instructions 
are defined on the following two pages. The instructions 
on page 148 are concerned with the movement of the full 36 
bit word between the SI Register and either the AC or 
storage. The instructions on page l49, are used to test 
the SI Register. There are a ntimber of other instructions 
used to test or to modify the SI Register. These may be 
found in the 709O Reference Manual and will be self- 
explanatory when the following instructions are thoroughly 
understood. 
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Lesson 12, (cont'd) 



PSEUDO OP. CODE ; S¥T (Sense Switch Test) 

DESCRIPTION ; This is a pseudo op. code which tests whether 
the sense switch (y) is on or off. (Where Y = 1, 2, 3» ^» 
5, or 6). If the sense switch is on, the computer skips 
one instruction. If the sense switch is off, the computer 
takes the next instruction in sequence. 



INSTRUCTION ; PAI (Place AC in Indicators) Octal code: +004i» 
FORMAT ; (Type d) 




DESCRIPTION ; The c(AC), positions P and 1-35, replace the 
contents of the Sense Indicator Register, The c(ac) remain 
tinchanged. 



INSTRUCTION ; PIA (Place Indicators in AC) Octal code; -00^6 
FORMAT ; (Type D) 




DESCRIPTION ; This is the reverse of the PAI instruction 
above. Contents of the Indicator Register move into the 
AC (positions P, 1-35). Positions S and Q of the AC are 
cleared and the SI remains vmchanged. 



INSTRUCTION ; LDI (Load Indicators) Octal code; +044l 
FORMAT; (Type B) 



OP CODE 



lA 



TAG 



J 



S.I 



1112:13 



18-20 21 



35 



DESCRIPTION ; The c(y) replace the contents of Sense Indi- 
cator Register. The c(y) remain unchanged. 



INSTRUCTION ; STI (Store Indicators) Octal code; +06o4 
FORMAT ; (Type B) 



OR CODE 



TAG 



S.l 



1112-13 



18-20 21 



35 



DESCRIPTION ; The c(SI Register) replace the c(y) in 
storage. The c(SIR) remain unchanged. 
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Lesson 12, (cont'd) 



INSTRUCTION ; ONT (On Test for Indicators) Octal code: +0446 



0P.C0DE|IA //////// TAG Y 



S,l 



1112-13 



18- 20 21 



35 



DESCRIPTION ; For each bit in the c(y) that is a one, the 
corresponding bit of the Sense Indicator Register is 
examined* If all the positions examined in the SI Register 
are ones, the computer skips one instruction* If any of 
the positions examined in the SI Register do not contain a 
one, the computer takes the next instiniction in sequence;^ 



INSTRUCTION ; OFT (Off Test for Indicators) Octal code; +0444 
FORMAT ; (Type B) 



OR CODE 



lA 



S,l 



mm 



TAG 



1112-13 



re- 20 21 



35 



DESCRIPTION ; This is identical to the ONT instruction ex- 
cept that the SI Register is examined for zeros to compare 
with the ones in the c(y). All zeros, skip one instruction. 
Any non-zeros, take the next instruction^ 



INSTRUCTION ; TIO (Transfer when Indicators On) Octal codes 
FORMAT ; (Type B) +0042 



OR CODE 



lA 



^M 



TAG 



S,l 



1112-13 



18-20 21 



35 



DESCRIPTION ; For each bit in the c(AC) that is a one, the 
corresponding bit of the SI Register is examined ♦ If all 
the positions exEunined in the SI Register are ones, the 
computer takes its next instruction from location T, 
Otherwise the computer takes the next instruction in 
sequence • 



INSTRUCTION ; TIF (Transfer when Indicators Off) Octal code; 
FORMAT ; (Type B) +0046 



OR 



lA 



TAG 



S,l 



1112-13 



18-20 21 



J 



35 



DESCRIPTION ; The ones in the AC are compared with corres- 
ponding zeros in the SI Register, If all ones match zeros, 
the computer takes its next instruction from location Y, 
Otherwise the computer takes the next instruction in se- 
quence. In all of the above instructions j the contents of 
both registers being examined remain unchemged* 
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Lesson 12, (cont'd) 

EXAMPLES ; 

1. Pick up a location called TOTAL. If bit 35 is ••one, 
go to SUBRl and if bit 35 is zero, go to SUBR2. Place the 
word in location TOTAL into the AC before going to the 
subroutine. 



OP 



VARIABLE FIELD 



LDI 


TOTAL 


PIA 




ONT 


=1B35 


TRA 


SUBR2 


TRA 


SUBRl 



REMARKS 



Place TOTAL into 
Indicator 
Also place it into 
AC 

If bit 35 of Indi- 
cator is on, skip 
one ins timet ion 
If bit 35 is off 
(zero) go to SUBR2 
Bit 35 was on (one), 
go to SUBRl 



2, Assume that there is a "flag" word already in AC, 
If bit 31 is on, go to HOLD; if bit 1 is on, go to STAND 
and if bit P is off, go to STOP, 



OP 



VARIABLE FIELD 



PAI 

CAL =1B31 

TIO HOLD 

CAL =1B1 

TIO STAND 

CAL = -0 

TIF STOP 



REMARKS 



Place c(ac) into 
Indicator 

Pick up proper bit 
for compare 

If bit 31 is on, 
go to HOLD 

Bit 31 was off, 
pick up next bit 
for compare pur- 
poses 



If bit 1 is on, 
to STAND 



go 



This puts a minus 
sign in position P 
(see page I38) 

If P bit is off, 
go to STOP 
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Lesson 12, (cont'd) 

EXAMPLES 

3» Assiime that an end-of— tape has been reached in 
writing output on Channel A, tape 7 (A7), Check Sense 
Switch 3. If it is on jin down position), this is the end- 
of-job (EOJ). If it is off (in u£ position), go to another 
tape to continue writing. 



c 



HALT 
EOJ 




REWIND 

AND UNLOAD 

TAPE 




WRITE COMMENT 
TO OPERATOR TO 
LOAD NEW TAPE 



CONTINUE 
PROCESSING 



LOC 



OP 



VARIABLE FIELD 



ETTA 

TRA ET 



TRA 



CONT 



REMARKS 



Is it end-of-tape? 

Yes, go to ET 
routine 

No, go on proces- 
sing 



ET 



RUNA 



SWT 



TRA 



TRA 



7 
3 

COMMNT 
EOJ 



Rewind and unload 
tape 7 

Test S.S.3 for end- 
of-file 

No (switch is up) 
go to write COMMNT 

Yes (switch is 
down) , go to EOJ 



Since this is only a tiny portion of a program to show 
use of S¥T, CONT, COMMNT, and EOJ are not defined. 
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Lesson 12, (cont'd) 

SENSE LIGHTS ; There are four Sense Lights, designated by 
(Y) , where Y represents lights 1, 2, 3 or 4 correspondingly- 
defined by positions 97 » 98, 99 and 100. In the use of 
Sense Lights, a particular condition will not automatically 
turn on a sense light. When the programmer has determined 
that a particular condition exists, he must use an instruc- 
tion to turn a sense light on or off to be used as ein indi- 
cation of the existence of that condition. 



PSEUDO OP ; SLN (Sense Light On) (y) 

DESCRIPTION ; This pseudo instruction turns on the Sense 

Light designated by (y) . 

PSEUDO OP ; SLF (Sense Lights Off) 

DESCRIPTION ; This pseudo instruction tiirns off all Sense 

Lights, 

PSEUDO OP ; SLT (Test Sense Light) (y) 

DESCRIPTION ; This pseudo instruction tests whether Sense 

Light (Y) is on or off. If Sense Light (y) is on, it is 

turned off and the computer skips one instruction. If the 

light is off, the computer takes the next instruction in 

sequence. 



EXAMPLE; 



To understand the use of Sense Lights, let us assume 
that we have a progrsun with the following peculiarities; 
During certain computations , a number will be in the AC 
whose sign is to indicate whether SUBRl or SUBR2 is to be 
followed at a later time in the program. If the sign is 
plus, SUBRl is to be entered and if the sign is minus, 
SUBR2 is to be entered. Unfortunately, between the time 
that the indicator appears in the AC eind the time the de- 
cision is to be made, other operations occur using the AC, 
so that the indicator is destroyed. This type of problem 
may be solved with the use of Sense Lights as shown below; 
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Lesson 12, (cont'd) 



LOG OP 



VARIABLE FIELD 



SLF 



REMARKS 

Sense Lights 
turned off at be- 
ginning of program 



SLT 



NOP 



Turn off Sense 
Light 1 

Skip one instnic, 



TPL JUMP 



SLN 1 



JUMP 



If sign + , go to 
JUMP, skipping one 
instniction 

Sign was - , tuna on 
Sense Light 1 to 
indicate SUBR2 will 
be entered 

Further computa- 
tions 



SLT 
TEA 



1 
SUBRl 



SUBR2 



Test Sense Light 1 

If light is off, 
go to SUBRl 

If light on, go to 
SUBR2 



SUBRl 
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Lesson 12, (cont'd) 

EXAMPLE ; 

Write a subroutine to read from A3. However, if Sense 
Light h is on, reading will be from A2, Records are 22 
words in length from both tapes and will be placed into 
location HOLD, HOLD + 1, etc. The Sense Light will be 
turned on, if necessary, each time a record is processed 
and the subroutine is called again. When EOF is reached, 
the job is finished. 



FROM CALLER 
(SEE NOTE BELOW) 



SET 
COUNTER 
TO ZERO 



SET 

COMMANDS 

FOR A2 



c 



HALT-EOJ 




SET 

COMMANDS 

FOR A3 



INCREASE 

COUNTER 

BY I 



RETURN TO 

CALLER AND 

MAIN PROGRAM 




BACKSPACE 
RECORD 



Note: The instruction dn the Main Program that leads to a 
subroutine is named the caller . When the subroutine is 
finished, control is returned to the Main Prograun* Each 
time the caller is encountered in the Prograjn, the sub- 
routine is entered (see page 133 for subroutine linkage). 
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Lesson 12, (cont'd) 
EXAMPLE — cont inued 



LOG 


OP 


VAK 


X 


TAPENO 


A3B 


Y 


TAPENO 


A2B 


READ 


STZ 


CNT 




CLA 


A2 




SLT 


k 




CLA 


A3 




STA 


RDS 




STA 


BSR 



VARIABLE FIELD REMARKS 



TCOX 



Define X as Chan, A, 
tape 3 1 Binary- 
Define Y as Chan. A, 
tape 2 , Binary- 
Set cotinter to zero 
Move A2 (defined below) 
into AC 

Test Sense Light k 
Light off, move A3 (de- 
fined below) into AC 
Preset to read either 
A3 or A2 

Preset to backspace 
either A3 or A2 (Note 
Octal codes under A2 
and A3 below) 
Wait xintil through 



RDS 
(Read 
Routine) 



RTDX 
RCHX 
TCOX 
TEFX 
TRCX 
TRA 



10 
* 

EOJ 
PEX 
1. 4 



Preset to A2 or A3 



Return to caller 



EOJ 



HTR 



Halt - end of job. 



PEX 
(parity- 
error 
routine) 



BSR 



CLA 
ADD 
STO 
SUB 
TZE 

BSRX 
TRA 



CNT 
= 1 
CNT 
= 10 
EOJ 



RDS 



Unreadable record (if 

zero) 

Preset to A2 or A3 



10 
HOLD 

A2 
A3 



CNT 



lORT 
BSS 

RTDY 
RTDX 



PZE 



HOLD, , 22 
22 



Read 22 words 
Assign 22 locations to 
HOLD 

In Octal! 076600001222 

In Octal: 076600001223 

(RDS = 076200001222) 

(bsr = 076^^00001223) 



Note: The last 4 Octal characters of location RDS and BSR 
specify the channel, mode and tape unit. Thus the STORE 
address (STA) does not change the operation, only the 
Input/Output device. 
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Lesson 12, (cont'd) 

INDIRECT ADDRESSING ; (IA) A brief definition of Indirect 
Addressing was given on page 21. Please review it before 
continuing on this page. Any instruction that is Indirectly- 
Addressable may be used to set the IA flag (one bits in 
positions 11-12), A list of these codes may be found in 
Appendix E of the IBM 709O Reference Manual, 

An instruction that is indirectly addressed calculates 
the presumptive location, goes to this location and gets 
its actual location from the effective location of the new 
instructions (effective location defined on page 93) • This 
statement is rather difficult to follow. It will be ftir- 
ther explained by a number of examples. 

An asterisk (*) placed directly after the Op, Code 
indicates that this instruction is indirectly addressed. 
This is a very powerful and useful programming tool and 
should be studied very carefully. 



EXAMPLES ; 

1, LOG 



OP 



VARIABLE 



REMARKS 



CLA »'*t-ii^'HOLD^ 



T 



/ 



y 



y 



Presumptive loc . of 
CLA is HOLD. Progreun 
goes to HOLD and finds 
the effective loc. to 
be AREA. This is then 
moved into the AC and 
the STO operation is 
ignored* 



(HOLDj^ STO ^AREA) 

Without the asterisk (*), the contents of location HOLD 
would be placed into the AC. Since it is indirectly ad- 
dressed, the contents of location AREA will be placed into 
the AC, 



2. LOC 



OP 



VARIABLE 



REMARKS 



AXT lj,_J. 

STO C*)-*{HOLD, 1; 



/ 



/ 



CLA 



.-/- ,^ ' 



CHOLD^r 



CLA 



/AREA') 



BLOCK 



This moves 1 into XRl 
Indirectly addressed, 
modified by XRl takes 
us to AREA, since it 
says in effect, HOLD-1. 
If XRl is less them 1 
(zero) the effective 
address would be BLOCK. 



Using an Index Register complicates the problem, but makes 
IA more powerful as a tool. In this case, the indirectly 
addressed STO instruction will place the contents of the AC 
into location AREA, unless XRl is zero, in which case the 
contents of the AC would be placed into location BLOCK, 
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Lesson 12, (cont'd) 

EXAMPLE: 



3. LOG 



OP 



VARIABLE 



REMARKS 



AXT 
AXT 
STZ (*) 



1, 2 

'^AVEj__r| 



Place 1 into XR2 
Place -1 into XRl 
(go to save + 1, emd 
store zeros in LAP -1 
(AB PZE) 



SAVE 



CAB)-* 
LAP 
CD 
MAP 



MAP, 2 / 



CLA* 

CLA* ^_-*'LAP^_27 

PZE 
PZE 
PZE 
PZE 



The STZ (indirectly addressed) will store zeros into 
LAP -1, unless XRl is zero, in which, case it will store 
zeros into MAP -1, If XR2 is zero, then zeros would be 
stored in LAP. 

The indirect addressing on SAVE and SAVE + 1 has no 
effect on the STZ instruction. 

The lines in the example above show the steps tetken by 
the computer to determine just where zeros are to be 
stored in the case where XRl is -1. If XRl and XR2 are 
both zero, it would be as follows: 



AXT 


0, 2 




AXT 


0, 1 




STZ C* 


'•*<jAyE_j^_iX 


zeros are stored in 
loc. MAP 



SAVE 



/ 
/ 

/AB 
/ 

TilAP) 



CLA*._ _(MAp7~2V 
CLA* LAP, 2 
PZE 
PZE 
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Lesson 12, (cont'd) 

EXAMPLES ; 

k. Assume that we want a subroutine that will calculate 
3* X + ^ (floating point). The address of X is in the AC 
(positions 21-35) /upon entrance to the subroutine. The 
answer will be left in the AC upon exit from the subroutine. 



LOC 



OP 



VARIABLE 



(caller 
will be:) 



REMARKS 



TSX CALC, k This is in the Main 

Program 



Subroutine 



CALC 



STA 



CLA 



CLA 



** 



FAD* 


CLA 


FAD* 


CLA 


FAD 


= k. 


TRA 


1. k 



Address of X into CLA 
instruction 

Pick up X into AC. 
Preset to loc. X 

Calculate 2X 

Calculate 3X 

Calculate 3X + U 

Return to "caller," 
end of subroutine 



5. In the problem above, if the "caller" was changed 
to: 



TSX 
PZE 



CALC, h 
X 



Subroutine 





CLA* 


1, 4 


Bring X into AC 


FAD* 


1. ^ 


Calculate 2X 


FAD* 


1, 4 


Calculate 3X 


FAD 


= k. 


Calculate 3X + k 


TRA 


2, k 


Return to caller 



CALC 
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Lesson 12, (cont'd.) 



115. Write a subroutine with arguments A, B, and C 
respectively. In the subroutine, calculate (in floating 
point) (2 * A + B) /C and retiirn to Main Program with the 
answer in the AC (solve with Indirect Addressing). 

Assume the caller looks like this: 

LOG OP VARIABLE FIELD REMARKS 

TSX CALC, 4 

TSX A 

TSX B 

TSX C 

return 

SUBROUTINE ; 

LOG OP VARIABLE FIELD REMARKS 

CALG 
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Lesson 12, (cont'd) 



PROBLEM 115 ; 



CORRECT ANSWER 



START 



MOVE A 
INTO MO 



MULTIPLY 
BY 2 



ADD B 



RETURN 

TO MAIN 

PROGRAM 



LOC 



OP 



VARIABLE FIELD REMARKS 



CALC 



T,DQ* 


1, ^ 


FMP 


= 2. 


FAD* 


2, k 


FDH* 


3, h 


XCA 





TRA 



4, k 



Pick up A in MQ 

Multiply by 
literal of 2 

2 * A + B 

(2 * A + B) /C 

Move quotient to 
AC 

Return to progrEun 
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LESSON 13 

GENERAL CONSIDERATIONS ; 

1. Always start the program by rewinding the tapes that are 
to be used. 

2. If temporary storage areas are to be used, always clear 
them out at the beginning of the program with STZ instroic- 
tions to make certain that the areas contain nothing but 
zeros. Never assume that anything is zero initially. 

3. Consider a large program as a series of subroutines. 
This gives you the advantage of being able to check out one 
routine at a time. 

k. Always flow chart the problem before attempting to code 
it. This is the easiest way to catch logic errors and it 
simplifies the problems of coding, debugging and modifying 
programs. 

5 . Teike maximtun advantage of Input/Output . Use prepared 
programs if available. 

6. Always check for End-of-File (when reading) and End-of- 
Tape (when writing) . 

7. If buffer areas are to be used, be sure that they are 
large enough. 

8. If the program is long enough to run over 10 minutes on 
the 7090* it should have restart capability. In this way, 
if there is trouble in running the program, it isn't neces- 
sary to go back to the beginning and start over. Csm go to 
the nearest restart point, 

9. Do only what is essential on-line. All possible outputs 
should be off-line. Stick to tape input and. tape output 
on-line. 

10. If Sense Lights are to be used in the program, turn them 
off at the beginning. 

11. Use as meiny system checks as possible: 

a. Keep record count of number of records in storage 

b. Keep control total if possible 

c. Keep limit checks (compare to a limit which is not 
to be exceeded) 

d. Keep tape labeling checks if tapes are to be 
mounted in sequence. 

12. Use messages to the operator where it will help to 
make things clear to him in running your progreim. 
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Lesson 13 » (cont'd) 

TRAPPING: Floating point traps were discussed briefly on 
page 51. Another form of trapping is called Transfer 
trapping . There are special instructions to enter and to 
leave the Transfer Trapping Mode of operation. These in- 
structions are shown on page l63» 

When the computer is operating in the trapping mode, 
control is transferred to location 0001, whenever the con- 
ditions for transfer have been met, 

EXAMPLE: TZE (Transfer on Zero) 

Normally, if the AC = zero, transfer to instruction 
contained in loc, Y. Otherwise computer takes the next 
instruction in sequence. 

In the Trapping Mode, if the AC = zero, the computer 
transfers to location 0001 for its next instruction. 

EXAMPLE 2 ; TRA (Transfer) 

This is an unconditional trajisfer, therefore the condi- 
tion for transfer is always met and control is always 
transferred to location 0001 in the Trapping Mode, 

Whenever the condition for transfer is not met, the in- 
struction is executed in the normal manner. 

The major use of the Transfer Trap Mode is in checking 
out a program. When operating in this Mode, the location 
of every transfer instioiction (with the exception of trap 
transfer instructions) replaces the address part of loca- 
tion 0000. This occurs whether the condition for transfer 
is met or not, 

A special trap trace program may be written, starting 
in location 0001, which will write out on a special tape, 
all trajisfer instructions for subsequent off-line printing. 
At the end of the trace program, control is returned to the 
main program which will continue until another transfer in- 
stiniction returns it to the trace program. 

When the information accumulated by the trap trace pro- 
gram is printed out , it will give the prograjmner a recoird 
of the contents of various registers at each transfer in- 
struction, providing the conditions for transfer were met. 
This can be extremely useful information to a programmer in 
checking a program which is not functioning properly. 

When the program has been debugged (corrected) , the 
Enter Trapping Mode instmction may be replaced by a NOP 
instruction, cutting off the entire trace program. 
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Lesson 13* (cont'd) 



x^ic t>3ra.p i.ra.cG piOgiaiu cou.j.u. ot/Oi-e unc iuilowlng 



information, beginning with a location designated TRAP, 



TRAP 
TRAP + 1' 

TRAP + 2 
TRAP + 3 

TRAP + 4 

TRAP + 5 



c(ac) positions S, 1-35 
c(ac) positions P and Q in bit posi- 
tions 3h and 35 
c JMQ) 

c(XRl) in the decrement part of the 
word 

c(XR2) in the decrement part of the 
word 

c(XR4) in the decrement part of the 
word 



INSTRUCTION ; ETM (Enter Trapping Mode) Octal code: +O76O 
FORMAT ; (Type E) OOO7 



OP. CODE 



vm/m^m 



OP. CODE 



S,l 



18-20 23 



35 



DESCRIPTION ; This instruction causes the computer to enter 
the transfer trapping mode. It turns on the trapping indi- 
cator and the trap light on the operators console. The 
computer will continue to operate in the trapping mode until 
a "leave trapping mode" instruction is executed or until 
the "clear" or "reset" keys are pressed on the operators 
console, 

INSTRUCTION ; LTM (Leave Trapping Mode) Octal code: -O76O 
FORMAT ; (Type E) 000? 



OR CODE 



S,l 



wmm^wh 



OP. CODE 



II 



18-20 23 



35 



DESCRIPTION ; This instruction turns off the trap indicator 
and the trap light on the operators console. Another ETM 
instruction would be required to put the program back into 
the trapping mode, 

INSTRUCTION ; TTR (Trap Transfer) Octal code: +0021 
FORMA.T ; (Type B) 



OP CODE 



lA 



3,1 



IIIS-13 



wm 



TAG 



18-20 21 



35 



DESCRIPTION ; This instruction causes the cominiter to take 
its next instruction from location Y, This makes it pos- 
sible to have eui ordinary tremsfer even when in the trap- 
ping mode. This is the only transfer instruction that will 
not cause control to be transferred to location 0001, when 
the conditions for transfer have been met and the machine 
is in the trapping mode , 
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Lesson 13, (cont'd) 



SORTING ; Tliis term refers to the procedure of arranging 
data according to certain specified characteristics. For 
example; a group of numbers may be sorted in such a way that 
the smallest .number comes first, followed sequentially by 
the next largest number, until all numbers are in order from 
smallest to largest. 

Sorting on the 709O is quite difficult. Fortunately, 
most organizations have "Sort Routines" already developed 
and the progreimmer merely has to use the applicable routine 
if he desires to do a sort in the program. Sorting is a 
slow process, taking up considerable machine time. 

On the following pages , an example of sorting is shown. 
This is not the fastest or best way, but it is fairly 
simple to understand. 

The problem is stated on page I65. What the progreun 
does is: 

1, Finds the smallest number by searching through the 
entire 100 numbers and places it into the first 
position of a temporary location, 

2, Although it has been moved to a temporary location, 
it is still present in the original 100 numbers, so 
the numbers are shifted so that all "words" above it 
raove down one, covering up the one we have moved. 

3, This process continues until all of the numbers have 
been moved to the Temporary area. Now they are in 
numerical sequence. 

k. The entire 100 numbers are then moved back to the 
original area as required by the problem, 

5, The job is done. 



Note: The term cells is used both in the flow chart and 
the program on the next two pages. This term is 
used to indicate a machine word and it is more 
commonly used among programmers than the term 
machine word. 
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Lesson 13 » (cont'd) 
EXAMPLE : 



PROBLEM ; One hundred niimbers are stored consecutively- 
beginning in location STORE. Sort the numbers (put them in 
sequential order) from smallest to largest, leaving them in 
the original block of locations. There are two instructions 
in the following program that have not beer, previously de- 
fined (SXA and TNX) , Look them up in the 709O reference 
manual . 

/start) 



PRESET NO. OF 

CELLS TO STORE 

IN TEMP. LOG. 



PRESET NO. OF 

CELLS IN LOC. 

STORE 



PICK UP 
A WORD 



SET ITSUOC. 

IN CASE IT 

IS SMALLEST 



SAVE 
THE LOC. IT 
OCCURRED IN 



PUT THIS 

NO INTO 

AC 




PLACE C(AC) 
INNEXT AVAIL. 
CELL OF TEMP. 



MOVE ALL W'OS 

ABOVE IT DOWN 

ONECELL 



PICK UP LOC. 

OF SMALLEST 

WORD 




TRANSFALL 

OF TEMP. 

BACK TO STORE 





f HALT-EOJ J 
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Lesson 13, (cont'd) 



LOC 



OP 



VARIABLE FIELD 



REMARKS 



START 


AXT 
AXT 


100, 1 
100, 2 






LOOP 


CLA 
SXA 
SXA 


STORE + 
SX2, 2 
NINS, 2 


100, 


2 


CAS 


GAS 
TRA 
TRA 


STORE + 
S^OITCH 
* + 1 


100, 


2 



Preset no. of cells to 

store into TEMP 

Preset the no. of words in 

STORE 



TEST 



TIX * - 3, 2, 1 

STO TEMP + 100, 1 
TNX TIIRU, 1, 1 



SX2 



Pick up first word left in 

STORE 

Save loc, in case 1st word 

is smallest 

Save the no. left in STORE 

Is this STORE no. less? 

Yes ( <) » set new 'compare 

No ( = ) , move down to 

next instruction 

No (>)» are we thni? No, 

compare rest of STORE 

Yes, save in TEMP area 

Is TEMP area full, yes - 

go to THRU. 



AXT **, 2 



CLA STORE + 99, 2 

STO STORE + 100, 2 

TXI * + 1, 2, 1 

TXL * - 3, 2, 99 

LXA NINS, 2 

TXI LOOP, 2, -1 



No, pick up loc, of 
smallest no. 
Move all numbers 
above, down one 

Is XR 2 < 99? Yes 

No, all have been shifted 

Repeat for next smallest no 



SWITCH SXA SX2, 2 



CLA 

TRA 



STORE 
TEST 



+ 100, 2 



THRU AXT 100, 2 

CLA TEMP + 100, 2 

STO STORE + 100, 2 

TIX * -2, 2, 1 

HTR* * 



Save location of smallest 
no. 



Transfer back 
to store 



STORE 
TEMP 

NINS 



BSS 100 
BSS 100 
BSS 1 
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Lesson 13 » (cont'd) 

PROGRAM TESTING ; 

On page x, a very brief summary of computer-programmer 
interaction was given. Now we will touch, lightly on each 
step of the process from coding to final output product. 
To prepare a program for operational use, the following 
steps must be observed after the problem has been analyzed, 
flow charted and coded on the appropriate coding sheets. 

1, The coding sheets must be sent to the keypunch 
organization. It is important to request that the cards be 
interpreted (this meains that whatever is punched in a card 
will be printed across the top of it). Each line of the 
coding sheet will become a punched card, 

2, ¥hen the cards come back from Keypunch, they must be 
compared with the coding sheets. The comparison must be 
extremely careful ajtid detailed, digit for digit. Any card 
containing errors must be destroyed and replaced with a 
corrected card, 

3, The deck of cards you now have is called the source 
program . The source program is sent to Machine Operations 
organization for assembly . The Fortran Assembly Program 
operates on the source program, changing the symbolic source 
program into language that is understandable to the com- 
puter. This is accomplished automatically by the computer. 
You request an Assembly Print-Out when submitting the source 
program for assembly. This allows you to make a final check 
of the program and the print-out will show the locations in 
storage of constants and assigned work areas. The assembled 
progreim is called the object progreim . 

k. Before the ob.lect progreun may be run against live 
data, it must be debugged (freed of all possible errors ) , 
The best ajid least expensive way of doing this is by run- 
ning the program against Test Data . Test data is written 
by the programmer to attempt to simulate operational data 
and to attempt to cover each different action taken by the 
program. Since the programmer is writing the test data, 
he can easily determine what the results should be after 
the data is run through the machine. In this manner, he 
cem check out his program before it is allowed to work on 
operational data. The test data must also be key punched 
and desk checked . 

5, The ob.ject program card deck and test card deck are 
sent to Machine Operations for a test run. Again, a print- 
out of the result is requested. The two card decks are 
transferred (off-line-not on the main computer) to tape, 
loaded into the 709O and the program execution is begun. 
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Lesson 13, (cont'd) 



6. If the program processes the test deck all the way- 
through, it is still necessary to check the print-out to 
make sure that the results obtained are as expected. 

7. If the computer hangs up (stops before processing is 
finished) , a memory print will automatically be furnished 
by the operator to give the programmer an idea of where the 
trouble occurred so that he may try to find and correct the 
error . 

8. If correction is to be made, the corrected card (or 
cards) must be put into the original card deck of the source 
program , replacing the cards that were in error. The pro- 
gram must then be reassembled before attempting to run 
again. It is possible to patch a program in such a way that 
reassembly is avoided, but patching will not be elaborated 
upon here. 

9. After corrections have been made, another test nin 

is attempted and this process is continued until the program 
is clean (no more errors apparent). A new program almost 
never runs through without errors . A programmer always ex- 
pects a few ineffective runs before he can clean up his 
program, but the important thing is to work as carefully 
as possible to avoid foolish clerical errors. 

10. It is also extremely important to avoid errors in 
basic logic when the program is in the planning stage. 
Careful flow charting and emticipating all contingencies in 
advance help to make for better programs. A good flow 
chart also helps others to understand the workings of your 
program and greatly assists you if modifications or cor- 
rections are required. 

11. ¥hen the output product is to be in printed form, 
it must be remembered that Binary words written on tape by 
the 7090 » are not intelligible. Each installation has 
several good subroutines for converting Binary numbers to 
Decimal characters. These subroutines should be used and 
the process should be accomplished off line whenever 
possible. 
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Lesson 13 f (cont'd) 



PROBLEM ; 

116, ¥rite a routine to compute the following 
expression: 

p 

A + BX + C (floating point ntunbers) 

Where A, B, and C are stored consecutively beginning in 
location HOLD and X is in the MQ, The Decrement part of 
the AC contains the address to which the routine will 
transfer upon completion of the problem. 



LOG 



OP 



VARIABLE 



REMARKS 
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Lesson 13, (cont'd) 



PROBLEM 116; 




SAVE THE 
RETURN 
ADDRESS 



CORRECT ANSWER 



CALCULATE 
B X X 




ADD C 






TOBX 








'' 








SAVE IN 

TEMPORARY 

STORAGE 




CALC a2 

ANDADD 

TEMP. 












1 




PLACE INTO 
LOC.STORE 



RETURN TO 
PROGRAM 



LOG 



OP 



VARIABLE 



REMARKS 



ENTRY 


ARS 


18 




STA 


RTN 




FMP 


B 




FAD 


C 




STO 


TEMP 




LDQ 


A 




FMP 


A 




ADD 


TEMP 




STO 


STORE 


RTN 


TRA 


♦* 


A 


DEC 


1.95 


B 


DEC 


3.84 


C 


DEC 


.98E-4 


TEMP 


BSS 


X 


STORE 


BSS 


1 



Save return address by- 
storing it in RTN 
Calculate BX 
Calculate BX + C 
Save in temporary storage 

Calculate A 

Calc. A^ + BX + C 
Place into loc. STORE 
Return to Main program 



Constants (values chosen 
at rgmdom since none were 
given in problem) 
Allocate storage positions 
to Temp, storage and the 
answer 
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Lesson 13, (cont'd) 

PROBLEM ; 

117. Read a 5 word record from Channel A, unit 6, in 
Binary. Place in location HOLD, HOLD + 1, etc. Solve the 
following equation using HOLD as A, HOLD + ,1 as B ajid HOLD 
+ 2 as C, 

«2 „2 
R = 2 (1 - — ^2 — ) floating point ntunbers 

Assume that there will be no overflow or underflow emd that 
the result of each arithmetic operation may be contained 
within one register. The answer (r) will be placed into 
loc, COMP. ¥rite the result on Channel C, unit 5, Binary, 
as a 5 word record: 

1st word = A, 2nd word = B, 3rd word = C, 4th = R, 
5th = C^. stop at EOF or EOT. 

Remember, that the Read and Write routines must be as com- 
plete as they are in lesson 10, Flow chart on this page 
and code on the next two pages. 

FLO¥ CHART 
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Lesson 13, (cont'd) 

PROGRAM 
LOG OP VARIABLE REMARKS 
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Lesson 13 f (cont'd) 

PROGRAM — continued 
LOG OP VARIABLE REMARKS 
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Lesson 13 » (cont'd) 



PROBLEM 117 ; 



c 



HALT-EOJ 



CORRECT ANSWER 




YES 



ZERO READ 
COUNTER 
















" 






1 


READ A 
RECORD FROM 
A6 INTO 
HOLD, ETC. 






<:;^ EOF?^ 


> 




NO 






,>/PARITY\ YES 
\ERROR^^ 


ERROR 
ROUTINE 



NO 



calculate 
aSb^c^ 



CALCULATE 
R 



STORE INTO 
COMP 












' 


• 


1 


WRITE ON 
C5 USING 
3 CHANNEL 
COMMANDS 






/^RITY^ 
\^ROR?/ 








YES 


ERROR 




ROUT" 


riNE 



HALT-EOJ 



YES 



NO 
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Lesson 13 » (cont'd) 



CORRECT ANSWER 



PROGRAM 



LOC 



OP 



VARIABLE 



REMAEtKS 



X 


TAPENO 


a6b 








y 


TAPENO 


C5B 








START 


STZ 


CNT 




Preset cotanter for Read 


RX 


RTBX 










(Read 
Routine) 


RCHX 
TCOX 

TEPX 


lOIN 
* 

EOJ 




Read tape 
End of file? 




TRCX 


PEX 




Parity error? 


( calcu- 
lation) 


LDQ 
PMP 
STO 


HOLD 
HOLD 
A2 




Calculate 


A^ 




LDQ 
PMP 


HOLD + 
HOLD + 


1 
1 


Calculate 


^ 




STO 


B2 










LDQ 

PMP 


HOLD + 
HOLD + 


2 
2 


Calculate 


^ 




STO 


C2 










CLS 


A2 






-(a2 + B2) /C^ 




FSB 


B2 




Calculate 




PDH 


C2 




Calculate 




XCA 












FAD 


=1. 










XCA 
PMP 


=2. 




Cal. 2 (l 


(A^ + B^). 
C2 ^ 




STO 


COMP 








(Write 


STZ 


CNT 




Preset counter for Write 


Routine) 


TCOY 


* 








AGAIN 


WTBY 












RCHY 


iOOUT 




Write a record 




TCOY 


* 










TRCY 


PEY 




Parity error? 




ETTY 






End of tape? 




TRA 


STOP 










TEiA 


START 
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Lesson 13, (cont'd) 
PROGRAM — continued : 



LOG 


OP 


VARIAK.E 


REMARKS 


EOJ 


HTR 


* 




STOP 


EQU 


EOJ 




PEX 


CLA 


CNT 




(Error 
Routine 
for Read) 


ADD 
STO 
SUB 
TZE 


= 1 
CNT 
=10 
EOJ 


Bad tape, if yes-go to EOJ 




BSRX 




If no, backspace 




TKA 


RX 


Back to try to read again 


PEY 


CLA 


CNT 






ADD 


= 1 




(Error 


STO 


CNT 




Routine 


SUB 


= 5 




for 


TZE 


STOP 


Bad tape, if yes - go to 


¥rite) 






STOP 




BSRY 




If no , backspace 




¥TBY 








TCOY 


* 






TRCY 


* 






TRA 


AGAIN 


Back to try writing again 


lOOUT 


lOCP 


HOLD, , 3 


Output A, B and C 




lOCP 


COMP, , 1 


Output R in same record 




lOCD 


C2, , 1 


Output C2 in same record 
and stop 


lOIN 


lORT 


HOLD, , 5 


Input Connnsmd 


CNT 


BSS 


1 




HOLD 


BSS 


5 




A2 


BSS 


1 


Allocate storage locations. 


B2 


BSS 


1 




02 


BSS 
END 


1 
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LESSON 14 

QUICK REFERENCE 

INSTRUCTIONS AND THEIR MEANINGS 
Refer 
to Page 1. MISCELLANEOUS INSTRUCTIONS ; 

kj XCA (+0131) Exchange AC and MQ - Reverses the two 

fields 
30 HTR (+0000) Halt and Transfer - Halts Program, if 

restart, goes to Y 
77 NOP (+0761) No operation - Progreim continues to 

next instruction 

2. FIXED POINT ARITHMETIC INSTRUCTIONS ; 

27 ADD (+OhOO) ADD - Add Y to AC 

29 SUB (+0402) SUBTRACT - Subtract Y from AC 

29 MPY (+0200) MULTIPLY - Multiply Y by MQ, Product 

in AC (and MQ if needed) 

69 RND (+0760 0010) ROUND - Increase AC by Binary 1 

if posit, 1 of MQ contains 1. 

29 DVH (+0220) DIVIDE OR HALT - AC and MQ are 

Dividend, Y is Divisor, Quotient in 
MQ, Remainder in AC. If can't 
divide, HALT. 

69 DVP (+0221) DIVIDE OR PROCEED - as above, except 

that if can't divide, continue with 
progreun with Div. Check Light on. 

69 DCT (+0760 0012) DIVIDE CHECK TEST - if indica- 
tor on, takes next instruction. If 
indicator off, skips one instruction. 

3. FLOATING POINT ARITHMETIC INSTRUCTIONS ; 

k6 FAD (+0300) FLOATING ADD - Add Y to AC 

h6 FSB (+0302) FLOATING SUBTRACT - Subtract Y from 

AC 

46 FMP j+0260) FLOATING MULTIPLY - Multiply Y by MQ 
h6 FDH (+0240) FLOATING DIVIDE OR HALT - AC 

divided by Y. Quotient in MQ, re- 
mainder in AC. If can't divide HALT. 

4. SHIFTING INSTRUCTIONS ; 

47 ALS (+0767) AC LEFT SHIFT - The AC shift left No. 

posit, in Y 28-35 
47 ARS (+0071) AC RIGHT SHIFT - As above, only 

shift to the right. 
73 LLS (+0763) LONG LEFT SHIFT - AC and MQ as one 

register. Shifted left no. places 

specified in Y 28-35. 
73 LRS (+0765) LONG RIGHT SHIFT - As above, only 

shift to the right. 
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Lesson l4, 

Refer 5. 
to Page 

27 

29 

30 

30 

73 

89 
89 
89 
89 



73 
31 
31 

^7 
^7 
77 

52 
53 

95 

95 
95 

95 
95 



(cont'd) 

STORE AND LOAD INSTRUCTIONS : 

CLA (+0500) CLEAR AND ADD - Move Y into AC 

STO (+0601) STORE - Move AC into Y 

LDQ ( +0560 J LOAD MQ REGISTER - Move Y into MQ 

STQ f-0600) STORE PROM MQ REGISTER - Move MQ to Y 

STZ (+0600) STORE ZEROS - Move zeros into Y, 

Sign to + 

STA (+0621) STORE ADDRESS - from AC2j^_2k*o Y2,_^^ 

STD (+0622) STORE DECREMENT - from AC to Y 



'18-20 *° ^18-20 



S, 1, 2 



to 



7. 



STT (+0625) STORE TAG - from AC. 

STP (+0630) STORE PREFIX - from AC, 

Y 
S, 1, 2 

TRANSFER INSTRUCTIONS (No Index ); 

TRA (+0020) TRANSFER - Transfer to instruction 
specified by Y 

TZE (+0100) TRANSFER ON ZERO - If AC = Zero 

transf . to Y, otherwise to next instr. 

TOV (+0l40) TRANSFER ON OVERFLOW - If AC overflow 
indicator on, transfer to Y, other- 
wise on to next instniction 

TPL (+0120) TRANSFER ON PLUS - If sign of AC +, 
tratnsf. toY, otherwise to next instr. 

TMI (-0120) TRANSFER ON MINUS - If sign of AC -, 
transf. to Y, otherwise to next instr, 

CAS (+03J^0) COMPARE AC WITH Y - if c(AC)> c(y) go 
to next instr. If = skip one instr, 
if <, skip two instnactions 

NZT (-0520) STORAGE NOT ZERO TEST - If c(y) are 
not 0, skip 1 instr. If c(y) are 0, 
on to next instruction 

ZET (+0520) STORAGE ZERO TEST - This is the op- 
posite of NZT instruction 

TRANSFER INSTRUCTIONS ( INDEX ) 

TIX (+2000) TRANSFER ON INDEX - If c(XR) :> Deer. 

XR reduced by Deer, and on to Y. 

Otherwise on to next instruction 
TXI (+1000). TRANSFER WITH INDEX INCREMENTED- Adds 

Deer, to XR cuid on to Y 
TXL (-3000) TRANS. ON INDEX LOW OR EQUAL-If c(XR) 

•< or = Deci*. go to Y. Otherwise on 

to next instruction 
TXH (+3000) TRANS. ON INDEX HIGH-If c(XR)>Decr. , 

go to Y. Otherwise on to next instr. 
TSX (+007^) IHANS. AND SET INDEX-Place 2's Compl. 

of Instr. CTR into XR. Next instr. 

from loc. Y, 
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Lesson l4, (cont'd) 

Page 8, INDEXING INSTRUCTIONS ; 

9h LXA (+0534) LOAD INDEX PROM ADDRESS - c'^Y^ 

Moves into specified XR 21-35 
9^ LXD (-053^) LOAD INDEX FROM DECREMENT - c(y) 

Moves into specified XR 3-17 
9^ AXT (+0774) ADDRESS TO INDEX TRUE - Positions 

2i_«e ^^ this instruction moves 

into specified XR. 

9. INPUT/OUTPUT INSTRUCTION AND COMMANDS ; 

120 RTD (+0762) READ TAPE DECIMAL - ¥ill select tape 

to be read from if followed by RCH 
120 VTD (+0766) WRITE TAPE DECIMAL - With the RCH 

will select tape to write, otherwise 

writes blemk 
120 BSR (+076k) BACKSPACE RECORD - Backspace 1 record 
120 ¥EF (+0770) WRITE END-OP^-PILE - Writes EOF gap 

£Lnd tape mark 
120 REW (+0772) REWIND - Tape rewinds to load point. 

Ready to run again. 
120 RUN (-0772) REWIND AND UNLOAD - Rewinds tape to 

-jjj ^ load point and unloads it 

120 TOO (+0060) TRANS. IF CIIAN. IN OP. - If Channel 

in operation, takes next instruction 
-^ . from loc, Y 

121 TRC {+QQ22) TRANS. ON REDUNDANCY - If parity in- 

dicator on, turned off and next in- 
-^ . struction from loc, Y 

121 TEP (+qq3q) trans, on END-OP-FILE - If EOF indi- 
cator on, turned off and next in- 
struction from loc. Y 

121 BTT (+0760) BEGINNING-OF-TAPE TEST - If indicator 

on, turned off and takes next instr. 
in sequence. If off, jumps one instr. 

121 ETT (-0760) END-OF-TAPE TEST - As for BTT, except 

„ tests EOT indicator 

121 RCH (+034q) RESET AND LOAD CHAN. - Used with the 

Read or Write instr, to specify First 
Data Channel Command 

121 IOCD-l/0 UNDER COUNT CNTRL, DISCON. - Reads or 

Writes the number of words specified 
in Decrement 

122 lORT - I/O OF RECORD, TRANS. Reads to end of re- 

cord or until word count to zero. 
Writes number of words specified in 
Decrement, Next command from LCH or 
else disconnects, 

10. LOGICAL INSTRUCTIONS ; 

138 CAL (-0500) CLEAR AND ADD LOGICAL WD. - As the 

CLA except sign goes into posit, P 

138 SLW (+0602) STORE LOGICAL WORD - As the STO ex- 
cept that bit from P goes into Sign 
position. 
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Lesson l4, (cont'd) 

Page 10. LOGICAL INSTRUCTIONS — continued 

138 ANA (-0320) AND TO ACCUMULATOR - Bits are matdied, 

using AND miles, result into AC 

138 ANS (+0320) AND TO STORAGE - As for ANA, except 

result into storage loc. Y 

139 ORA (-0501) OR TO ACCUMULATOR - Bits are matched, 

using OR rules, result into AC 

139 ORS (-0602) OR TO STORAGE - As for ORA, except 

result into storage loc. Y 

139 ERA (+0322) EXCLUSIVE OR TO AC - As for ORA, ex- 
cept rules for EXCLUSIVE OR apply 

142 LGL (-0763) LOGICAL LEFT SHIFT - AC and MQ 

treated as one. Shifted left no, 
places in 28-35, Sign of AC no chg, 

1J^2 LGR (-0765) LOGICAL RIGHT SHIFT - As for LGL, 

only shift is to right, 

11. SENSE INDICATOR INSTRUCTIONS ; 

148 PAI (+0044) PLACE AC IN INDICATORS - c(AC)P, 1-35 

into Indicator 
148 PIA (-0046) PLACE INDICATOR IN AC -Reverse of PAI 
148 LDI (+0441) LOAD INDICATORS - c(y) into Indicator 

148 STI (+0604) STORE INDICATORS - Reverse of LDI 

149 ONT (+0446) ON TEST FOR INDICATORS - One bits in 

Y and SI are compared. If =, skip one 
instr. If not =, takes next instr, 

149 OFT (+0444) OFF TEST FOR INDICATORS - As ONT, ex- 
cept SI checked for zeros. 

149 TIO (+0042) TRANS. IF INDICATORS ON - One bits in 

AC and SI are compared. If =, next 
instruction from loc. Y 

149 TIF (+0046) TRANS. IF INDICATORS OFF - Ones in AG 

compaired with zeros in SI. If =, next 
instruction from loc. Y 

12. TRAPPING INSTRUCTIONS ; 

163 ETM (+0760 0007) ENTER TRAPPING MODE - Causes 

computer to enter trans, trap, mode 

163 LTM (-0760 0007) LEAVE TRAPPING MODE - Turns off 

trap indicator emd trap light. Takes 
the computer out of trap, mode 

163 TTR (+0021) TRAP TRANSFER - Next instruction from 

loc. Y. Only normal transfer allowed 
when in trapping mode. 

13. PSEUDO OPERATION CODES ; 

60 COUNT - COUNT - First card of symbolic deck. 

Gives number of cards in program. 
60 END - END - Last card of symbolic deck. 
60 BSS - BLOCK STARTED BY SYMBOL - Allocates 

block of storage. First loc, of block 

tagged by a symbol. 
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Lesson l4, (cont'd) 

Pa^e 13. PSEUDO OPERATION CODES— continued 

"-^ ^^^ - i-i^ua ^.i-Ku - Assigns one word and puts zeros 

into S, 1, 2. Gem specify Address, TAG, 
Decrement 

81 EQU - EQUIVALENT - Used to define a symbol 

81 OCT - OCTAL DATA - Data generating, series of 

variables 

82 DEC - DECIMAL DATA - Data generating, decimal in- 

tegers, fixed PT or floating PT. 
148 SFT - SENSE SWITCH TEST - If Sense Switch (l-6) 

is on, skip one instr. Otherwise takes next 
152 SLN - SENSE LIGHT ON - Turns on Sense Light 

designated by Y. 
152 SLF - SENSE LIGHT OFF - Turns off all Sense 

Lights. 
152 SLT - SENSE LIGHT TEST - Tests Sense Light 

designated by Y, If on, turns off and skips 

one instruction. 



REVIEW AND SELF-TEST 



The following pages contain another review and 
self- test. Again, page references will be given with the 
correct answers and it is suggested that the reference be 
checked on each question ajiswered incorrectly. 

Consider this test to be closed book . Use only 
the quick reference to instructions at the beginning of 
this lesson. Do not refer to any other part of the book 
while you are working the problems. 

There will be 25 questions covering the high 
lights of the entire course and a problem to be flow 
charted and coded. Answer all questions and complete the 
coding before checking the correct answers. The answers 
to the 25 questions may be fovmd on pages I90, I91 and the 
flow chart and correct solution to the problem on pages 
192, 193 and 194. 

Score this test as you did the previous one in 
Lesson 9. Your total score on the two parts of the test 
should be 70 or over and you should not take over two 
hours in completing the entire quiz. 
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Lesson l4 , (cont'd) 
PROBLEMS ; 

118. Flow chart a typical Read Tape error routine: 




READ 
TAPE 
AGAIN 



119, Flow chart a typical Write Tape error routine: 
TAPE^\ YES 




ERROR ?. 



WRITE 

RECORD 

AGAIN 



120. Using AND logical rules with MASK OCT 000777777777 
Before: 



Oil Oil I I 001 I 01 II 10 



■♦0 



After: 



+ 15 7 1 5 7 



121. Using OR logical rules with MASK OCT 007777000000 
Before: 



After: 














01 1 01 1 


1 1 001 1 01 1 













-1-15 7 I 5 7 



122. Using EXCLUSIVE OR logical rules with MASK as in 
problem 120 



Before! 



After: 



H 



Olio I I I I 001 I 01 I I I o-»- 



+ 15 7 1 5 7 



-*0 
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Lesson l4, (cont'd) 

123 » a. How many sense switches are there? 
b. How many sense lights are there? 



124. Assiime that a "flag" word is already in the AC. 
If bit 15 is on, go to AREA and if bit 27 is off, go to 
STOP. ¥rite a partial program to accomplish this action. 



LOG 



OP 



VARIABLE 



REMARKS 



125, LOG 



OP 



VARIABLE 



REMARKS 



AXT 1, 1 

STO* Block, 1 

STO HOLD 

BLOGK GLA AREA 

STO FIELD 

In the little program above, the STO* will place c(AC) 
into location , 

126. In the program above, if the AXT looked like this! 

AXT -1, 1 

The STO* will place c(ag) into location 



127. When operating in the trapping mode, control is 
transferred to what location when the conditions for 
transfer have been met? 

Location 



128, The program, before assembly, is called the 
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Lesson l4 , (cont'd) 

129. LOG OP VARIABLE 
LXD HOLD, 1 

HOLD PZE 6, U, 2 
What is loaded into XRl? 



130. XR4 contains the nvaaber 7 , 

Instr. TIX HOLD, k, 5 
AA OLA AREA 

a. After execution, what is in XR4? 

b. Program moves to location 



131, In problem I30, if the number in XRU was 3'. 

a. After execution, what is in XR^? 

b. Program moves to location 



132, XRl contains the niunber 2: 

Instr. TXI HOLD, 1, 5 
AA CLA AREA 

a. After execution, what is in XRl? 

b. Program moves to location 

133, XR2 contains the number 13q 

Instr, TXL HOLD, 2, 12 
AA CLA AREA 

a. Program moves to 



b. After execution, what 
is in XR2? 



Op. 



Variable 



13^, In storage, location HOLD 
looks like this? 

CLA 50, 2 
(+0500) 

Show the instructions that will move the Op, Code into 
loc, AA, TAG into loc. BB and Address into loc. CC. 



I8i* 



Lesson l4, (cont'd) 

135* Show storage locations AA, BB and CC after problem 
13^ has been executed, 

AA 



BB 



CC 



136, Show the Octal representation of the following 
constants* 



a, DEC 17B14 



b. DEC 12 

c. OCT 17563 

d. DEC kE-k 



137. Problem: If A> B, go to loc. HOLD, If A = B, 
go to loc. HOLD +1, If A <:B, go to loc. HOLD + 2, Show 
a partial program to accomplish this action. 



LOC 



OP 



VARIABLE 



REMARKS 



138. Show the floating point word for the following 
number: 



276 



10 



Show the word in Octal. 

Char, Mantissa 
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Lesson l4, (cont'd) 

139 • Show the following numbers in normalized form, 
a. 12476. 



10 



b. . 00035^0 

c. 101 001„ 



d. 117.25 



10 



ihO, Show the Characteristic (in Octal) for the follow- 
ing floating point numbers: 



a. -25 



10 



D 



CHAR. 



b. 163 



10 



1^1, Four numbers are packed into a word at loc. HOLD 
as follows: 

Q 



2 3 4 



I 8 9 1718 2627 35 

Unpack number 3 and place into location HOLD 1 
in positions S, 1-8, Show a partial program to accomplish 
this action: 



LOC 



OP 



VARIABLE 



REMARKS 



l42. Add two fixed point numbers; A(B0) and B.(B0) . 
Move in the AC so that' the Binary point will be at BI6 and 
store in HOLD, 



LOC 



OP 



VARIABLE 



REMARKS 
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Lesson l4, (cont'd) 

PROBIyEM ; 

1^3 . On Tape 1, Channel A, are 100 values of X. On 
Tape 2, Channel A, are 100 values of Y (both sets in 
floating point). For each pair of X and Y, calculate X , 

2 

Y ajid XY, Write a record on Tape 5* Channel C, containing 

2 2 

X, Y, X , Y and XY ( in the order given aind also in float- 
ing point). Stop at end-of-tape. 

Use Storage loc, HOLD for X, HOLD + 1 for Y, HOLD + 2 
for X^, HOLD + 3 for Y^ and HOLD + k for XY. 

PLOW CHART 
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Lesson l4, (cont'd) 

PROGRAI'I 
LOG OP VARIABLE REMARKS 
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Lesson l4, (cont'd) 

PROGRAM — continued 
LOG OP VARIABLE REMARKS 
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Lesson l4, (cont'd) 
PROBLEM 

118. 



CORRECT ANSWERS 




INCREASE 
COUNTER 
BY I 



119. 



V^UNREAO 




BACKSPACE 



READ 
TAPE 
AGAIN 



ALT 
READABLE RECORD 



D 



(page 122) 




YES 



INCREASE 

COUNTER 

BY I 




BACKSPACE -» 



ERASE 
TAPE 



TURN OFF 

PARITY 

LIGHT 



WRITE 

RECORD 

AGAIN 



(page 124) 



120. 



/^ HALT ^ 
VBAD TAPEy 



After: 



0000000000 I I M I I 0-*- 



^ (page 137) 



+ 0001 57 



121. 



After; 



01 101 I I I I I I I II I I I0<^ 



-♦0 



(page 137) 



+ 15 7 7 7 7 



122. 



After: 



1 101 I I I I I 00 1 00001' 



(page 137) 



123. 



+ 15 7 6 2 

a. 6 (page 1^7) 

b. 4 (page 152) 



124. 



LOG OP 



VARIABLE 



REMARKS 



PAI 




Place c(AC) into 
Indicator 


CAL 


=1B15 


Pick up bit 15 to 
compare 


TIO 


AREA 


If 15 on, go to 

AREA 


CAL 


=1B27 


If off, pick up 
bit 27 


TIF 


STOP 


If off, go to STOP 



(pages 148-149) 
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Lesson l4, (cont'd) 
125. HOLD (page I56) 



126. FIELD (page I56) 



127. LOG. 0001 (page I62) 



136. a. +00021^0000000 

b. +204600000000 

c. +000000017563 

d. +165644000000 

(page 83) 



128, Source program (pg.167) 



129. 



(page 94) 



130. a. 2 
b. 



(page 95) 



HOLD 



131 = 



b. AA 



(page 95) 



132. a. 7 



(page 95) 



b. HOLD 



133. a, HOLD 



b, 13 



^^10 = ^"^8 
(page 95) 



8 



134. LDQ HOLD 

LLS 8 

ALS 27 

STO AA 

CLA HOLD 

STT BB 

STA CC 



To move 
Op, Code 

To move 

TAG 
To move 
Address 



135. 



n 


AA 


s 

+ 


00 1 1000 00 0|//^ 


1^ v_^ >^ ^11 

5 

BB 


V/.^^^'A 


18 20 

2 
CC 







21 



^5 
^ 2 



137. LOG OP 



VAR. 



REM. 



CLA 
CAS 



A 
B 



TRA HOLD 
TRA HOLD 1 
TRA HOLD 2 



(page 77) 



A> 
A = 

A< 



138, 



CHAR 



MANTISSA 



2 I I 



4 2 4 



(page 4l) 



139. a. 
b, 
c. 
d. 



,12476 X 10^ 
.35 X 10"-^ 

,101001 X 2^ 
.11725 X 10-^ 

(page 4l) 



140, -253^Q=-3l8=-011001.2 = 
.11001x2^ (200+5 = 205g) 

E I2 5| 



a. 



l63io=2^38 = 
010100011,2 = 
. 10100011x2 ■'■^ 



b. 



(200 + 10 = 210g) 



(Pg. ^1) 



+ 

— 2 I 



141. 

LOG OP 



VAR, 



REMARKS 



GAL HOLD Move to AC 
ANA MASK Blank all 

but 3 
ALS 18 Shift Left 
SLW HOLD 1 Store 
MASK OCT 000000777000 

(page l46) 

142, LOG OP VAR REM 
CLA A 
ADD B 
LRS 16 
STO HOLD (pg. 7^) 
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Lesson ik , (cont'd) 
PROBLEM li»3 ; 



FLOW CaiART 




SET ERROR 
COUNTER 



BRING IN 

ALL OF X 

ANDY 




SET COUNTER 
TO 100 



MOVEX AND 

Y TO HOLD 
ANDHOLD+I 



YES 



ERROR 
ROUTINE 



CALCULATE 

X^Y.^XY 
AND STORE IN 
HOLD +2.3,4. 












' 


' 


1 


1 


WRITEOUT 
THE RECORD 






,/^RITE)\. 

TAPE "; 

X^ROR'/ 








YES ^ 


ERROR 




ROUT 


■|NE 



NO 



EOT? 



NO 



DECREMENT 

XRI TO PICK 

UP NEXTVALUE 

OFXAND Y 



YES 



HALT-EOJ 
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Lesson lA-, (cont'd) 







PROGRAM 




LOG 


OP 


VARIABLE 




REMARKS 


X 


TAPENO 


AlB 






Y 


TAPENO 


A2B 






Z 


TAPENO 


C5B 






START 


AXT 
TCOX 


10, 1 

* 




Set coointer to try again 


RDX 


RTBX 
RCHX 
TCOX 
TEFX 
TRCX 


lOX 

* 

STOP 
PEX 




Read a record 




AXT 


10, 1 




Set cotinter to try again, 




TCOY 


* 




reading Y 


RDY 


RTBY 
RCHY 
TEFY 
TRCY 


lOY 

STOP 

PEY 








AXT 


100, 2 




Set counter to 100 


UOOP 


CLA 


X + 100, 


2 






STO 


HOT,D 




Move X and Y to 




CLA 


Y + 100, 


2 


output area 




STO 


HOLD + 1 








T,DQ 
FMP 


X + 100, 
X + 100, 


2 
2 


Calculate X 




STO 


HOLD + 2 








LDQ 
FMP 


Y + 100, 

Y + 100, 


2 
2 


2 
Calculate Y 




STO 


HOLD + 3 








LDQ 
FMP 


X + 100, 
Y + 100, 


2 
2 


Calculate XT 




STO 


HOLD + k 
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Lesson l4, (cont'd) 



PROBLEM 143 ; 

LOG OP 



PROGRAM — continued 



VARIABLE REMARKS 



WDZ 



TCOZ 


* 




AXT 


5, 1 




¥TBZ 






RCHZ 


100 




TCOZ 


* 




TRCZ 


PEZ 




ETTZ 






TRA 


STOP 




TIX 


LOOP, 2, 


1 



Set nxmber of times to try- 
Write a record on tape 



End of Tape? 

Yes, go to STOP 

No , go back to loop 



STOP 



HTR 



End of job 



PEX 



BSRZ 

TIX 

TRA 



RDX, 1, 1 
STOP 



Try 10 times 
Bad tape 



PEY 



BSRY 

TIX 

TRA 



RDY, 1, 1 
STOP 



PEZ 



BSRZ 

WTBZ 

TCOZ 

TRCZ 

TIX 

TRA 






WDZ, 1, 1 
STOP 



Backspace 
Erase tape 



Try again? Yes , to WDZ 
No , bad tape 



100 

lOY 

lOX 

X 

Y 

HOLD 



lORT 

lORT 

lORT 

BSS 

BSS 

BSS 

END 



HOLD , 
Y, , 
X, , 
100 
100 
5 



, 5 

100 
100 



Output Command 

Input Y Command 

Input X Command 

Allocate input areas for 

X and Y 

Allocate output area 
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LESSON 15 



SAMPLE PROGRAM ; Most of the examples and problems through- 
out this book showed only partial progreims , enough to solve 
the particular problem being presented. The sample program 
that follows attempts to show a complete source program , 
starting with the statement of the problem to be solved and 
followed by the programmers' flow chart and the coding re- 
quired to execute the problem. 

The Source Program on pages I98 and 199 shows the 
actual print-out the programmer will receive. Each line 
represents one punched card of the Source Card Deck (refer 
to page 167) . 

The following five pages show the cards of the Object 
Program after assembly. These contain all the information 
contained in the Source Program, ready to be used by the 
computer to operate on live data. 



PROBLEM 

Given a block of no more than 1000 floating point 
numbers, located at AREA, AREA + 1, etc. The last word in 
the block contains all binary ones. 

Find the number of words in the block (excluding the 
word containing all ones) and place the number into 
location NIB, in floating point. 

Find the average of all of the words and place it into 
location TAVE. 

Find the average of all plus words and place into 
location PAVE. 

Find the average of all the minus words and place into 
location MAVE. 

Vhen all averages have bee-n found and put into the 
proper locations, the job is doneo 
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Lesson 15, (cont'd) 



FLOW CHART 




SET NO. IN 

AREA = 

ZERO 



INCREASE 
NIA 
DECREMENT 
TAG XR 



SET XR 

=1000 FOR 

USE AS TAG 




CONVERT 

NIB TO 

FLT POINT 



SAVE IN 
NIB 



PRESET TAG 

TO SUM 
AREA,AREA+I 
ETC. 



PRESET 
SUM=0 



SUM THE 
BLOCK OF 
NUMBERS 



CALCULATE 
AVERAGE 
AND SAVE 



5 
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Lesson 15, (cont'd) 



FLO¥ CHART — continued 



i 



preset minus 
^^plus totals 
/counts = 

ZERO 



PRESET XR 
TO TOTAL 
IN AREA 



ADD TO 

MINUS 

TOTAL 



INCREASE 
MINUS 
COUNT. 



PRESET XR 
TO USE AS TAG 
IN CALCULATVi 




YES 



DECREMENT 
TAG XR 




ADD TO 

PLUS 

TOTAL 



INCREASE 

PLUS 

COUNT 



CALCULATE + 
AVERAGE AND - 
AVERAGE AND 
SAVE 



( HALT-EOJ j 
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_H. <^^ ^H « 

00000 
00001 
00002 
00003 
00004 
00005 
00006 


0774 00 1 00000 


START 


AXT 




9/05/62 PAG£ I 


0,1 


0774 00 2 01750 
0500 00 2 02030 
0402 00 02045 
0100 00 00007 
1 00001 1 00006 
1 77777 2 00002 


LOOP 


AXT 
CLA 
SUB 
TZE 
TXI 
TXI 


1000,2 

AR5A+1000,2 IS IT THE END 


TNIB YES 


*+ 1,1,1 NO, BUMP THE COUNT OF Nf8 
L00P,.2f-l TRY NEXT WORD 


00007 
COOIO 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00020 
00021 
00022 
00 02 3 
00024 
0002 5 
00026 
00027 
00030 


0754 00 1 00000 
0634 00 1 02030 
-0 501 00 02044 
0300 00 02042 
0601 00 02031 
0600 00 02032 


TNI 8 


PXA 
SXA 


,1 PUT COUNT IN AC 
FXNI6,1 SAVE FIXED POINT COUNT 





ORA 
FAD 

sto 

STZ 


=0233000000000 CONVERT FIXED POINT TO 
=0 FLOATING POINT 


NIB SAVE FLOATING POINT NIB 
TOTAL PRESET SUM TO ZERO 


0774 00 2 00000 
0500 00 2 00060 
0300 00 02032 

1 77777 2 00021 

2 00001 I 00016 
0241 00 02031 

-0600 00 02033 
0600 00 02034 
0600 00 02035 
0600 00 02036 
0600 00 02037 
U534 00 1 02030 


LOCPl 


AXT 
CLA 
FAD 
TXI 


0,2 PRESET PAG FOR ADDING AREA, AREA+l, ETC. 
AREA,2 SUM THE 


TOTAL BLOCK OF NUMBERS 
»+l,2,-l BUMP TAG FOR AREA 


■" ■ " 


TIX 

FOP 


LeOPl,l,l ALL THRU SUMMING, NO 
NIB YES, CALCULATE 


STO 
STZ 
STZ 
STZ 
STZ 
LXA 


TAVE AVERAGE AND SAVE 
PTOT PRESET TOTALS 


MT0T AND COUNTS 
PC NT 


MCNT 

FXNIB,! PICK UP NUMBER IN BLOCK 


00031 
00032 
00033 
00034 
000 35 
000 36 


0774 00 2 00000 
0500 00 2 00060 
0120 00 00052 
0300 00 02035 
0601 00 02035 
0500 00 02037 


LO0P2 


AXT 
CLA 
TPL 

FAD 
STO 

CLA 

FAD 

ST 9 


0,2 PRESET TAG FOR AREA 
AREA, 2 PICK UP NUMBER 


PLUS IS IT PLUS, YES 
MTOT NO 


MTOT 

MCNT BUMP COUNT OF 


00037 
00040 


0300 00 02043 
0601 00 02037 


=1.0 MINUS NUMBERS 



o 

H 
VJI 



o 



00044 0241 00 02036 



00045 -0600 00 02040 

0004 6 050 00 i)2035 

00047 0241 00 02037 
00 050 0601 00 02041 



00051 0000 00 00051 
00052 0300 00 02034 



00057 
00060 



02030 
02031 



02032 
0203 3 
02034 
02035 



02036 



STOP 
PLUS 



PPP 
STQ 

CLA 
FOP 
STO 
HTR 
FAD 



00053 0601 00 02034 
_0M54_J)50CL_00._0_02.036_ 

00055 0300 00 02043 

00056 0601 00 02036_ 



STO 

CLA 
FAD 
STO 



0020 00 00041 



AREA 



TRA 
BSS 



FXNIB 

_ NJB^ 
TOTAL 
TAVE 



BSS 
BSS 
BSS 
BSS 



PTOT 
MTOT 



BSS 
BSS 



PCNT BSS 



PCNJ 

p~ave" 

MTOT 
MCNT 

MAVE- 

«■ 

PTOT 

pfof 

PCNT 
= 1.0 
PCNT 
TEST 

ceo 



.PLUS_„AyEjRAGE 

CALCULATE MINUS 
AVERAGE 



ALL THRU STOP 
Sy M_.P LU S .«UMB E.R S 

BUMP PLUS 
COUNT 



B35 COUNT OF NUMBER IN AREA 

FLOATING POINT COUNT OF NUMBER IN AREA 

TOTAL OF ALL NUMBERS 

AVERAGE OF ALL NUMBERS 

PLUS NUMBERS TOTAL 

MINUS N UM B EjR S JO T A L 

plus" NUMB E RS"" C OUNT 



w 
u 
o 

H 



O 
O 

a 



02037 
02040 
02041 



MCNT BSS 



PAVE 
MAVE 



BSS 

BSS 



END 
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PAGE 2 



M I NUS NUMBERS C OUN T __ 
P L U S NUMB E R S~ " A V E R A G E 
MINUS NUMBERS AVERAGE 



LITERALS 
02042 000000000000 



02043 201400000000 

02044 23300000 0000 

02045 777777777777 



Lesson 15, (cont'd) 



POST PROCESSOR ASSEMelV DATA 



2046 IS THP FIRST LOCAf ION NOT USED VyThTSRROG^^^^ 



REFERENCES TO DEFINED SYMBOLS 

20 31 NIB 13, 22 

_ 60 _ AREA 2, 16, _ 32 

2 LOOP 6 ~ ■■ 

2041 MAVE 50 

2037 MONT 27, 36, 40, 47 

203^ MTOT 25, 34, 35, 46 

2040 PAVE 45 

_._ 2036 _ PCNF 26, 44, 54, 56 

52 PLUS 3"3 

2034 PTOT 24, 43, 52, 53 

51 STOP 

2033 TAVE 23 

41 TEST 57 

__ 7 TNie 4 

2030 FXNIB 10, 30 

16 LOOPl 21 

32 L00P2 42 

START 

2032 TOTAL 14, 17 



NO ERROR IN ABOVE ASSEMBLY. 
TU'E TO COMPILE/ASSEMBLE WAS 3 MILLIHOURS. 
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Lesson 15 » (cont'd) 



CONCLUDING REMARKS ; As a final step in this course of 
instruction, turn to the Index at the back of the book and 
read each term and phrase. If there are any that you do 
not understand thoroughly, please turn to the indicated 
page (or pages) and review the topic. 

It must be understood that what you have learned is 
only the beginning of the learning process. To become an 
accomplished progreumner, you must work with the machine and 
with the problems to be solved by the machine. Nothing can 
be substituted for experience. 

Many of the areas covered in the book only give you a 
basic idea that such a method exists. No more is possible 
dLn a book of this nature (or in a short lecture course, for 
that matter) . Constant use of the concepts and instruc- 
tions will do more than anything else to implant them 
firmly in your mind. 



You will find this book to be helpful as a source of 
review and reference as you learn more about programming. 
The only way to learn more about prograjmning is to work 
as a programmer. 



You now have enough knowledge of the terminology, 
techniques, and operating instructions of the 7090 com- 
puter, that you should feel confident in being able to 
pull your own weight as a fledgeling programmer. Working 
tuider the supervision of an experienced programmer will 
complete your education. 



If there are any areas in the book that you feel are 
inadequately covered, feel free to write to the author 
with your comments and remarks. They will be evaluated 
ajid, if acceptable, will be used for futtire revisions of 
the book. 
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INDEX 



Addre s s ing , 15 

Address modification, 93 » 98 

Algebraic addition, 27 

Algebraic subtract, multiply, divide, 29 

Arithmetic operations, vii, 2? , 29, k^ ^ k6 

Arithmetic symbols, 59 

Assembly, x, 60, 16? 

Asterisk (*), use of, 63, 6k 

Binary arithmetic, 5 

Binary numbering system, 1, 2 

Binary, Octal, Decimal conversion, 12 

Binary point, 2?, 37, 4l, 7^ 

Bits, 15 

Buffer, 18, 128 

Call or Caller, 15^ 

Card Reader, viii 

Cells, 164 

Central Processing Unit (CPU) , 17 

Channel , viii , 120, 121 

Characteristic, kl, 42, 51, 54 

Check indicators , 69 

Clean program, I68 

Closed subroutine, 133 

Computation phase, vii 

Connector, 102 

Constants, use of, 81, 83 

Data Channel, viii , 120, 121 
Debug, 162, 167 
Decimal numbering system, 1 
Decimal to Octal conversion, 11 
Define symbol, 55, 5^, 63, 81 
Density (high, low), viii 
Desk check, I67 

Effective address, 93 
Element, 63 
End-of-File gap, 119 
End-of-Record gap, II9 
Exponent, 4l, 42, 51 
Expression, 63 
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Fixed point operations, 27, 29 

Fixed word length, I5 

Flag, 37, 38, 150, 156 

Floating point arithmetic, 45 

Floating point operations, 4l , kS 

Floating point trap, 51 

Flow charting, ix, 36, 65. 66 ^ 102 

Format for program writing, 32 

Format of instructions, 21, 22 

Fortran Assembly Program (FAP) , x, 60, 82, I67 

General program considerations, I6I 

Hemg-up, 168 
Header label, II9 
High density, viil 
Hollerith, 82 

Index Registers, 17, 93, 97, 103 

Indicators, 69 

Indirect addressing, 21, 156 

Input ,vli, 120 

Input/Output Package , 128 

Instruction formats, 21, 22 

Integer, 37, hk 

Interpret punched cards , ix/x , I67 

Keypvmch, x, I67 

Labels, II9 

Least significant, 54 

Left adjusted, 38 

Literals, use of, 83, 126, 127 

I.- i V e d a t a , 1 6 7 

Load poxnt, iiy 

Logical operations (AND, OR), I37 

Loop, 56, 63, 93, 97, 102, 103 

Low density, viil 

Machine word , 15 

Mantissa, hi 

Masking, 22, l40, l44 , l47 

Memory , 15 

Memory print, I68 

Most significant, 54 

Multiple defined symbol, 55 
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Normalized number, ^1 

Object program, I67 

Octal nxunbering system, 1, 9 
Off-line ,vii, l6k , I68 
Open subroutine , 133 
Output ,vii, 120 
Overflow, 31, 51 

Packing, l40 

Parity check, 123, 125 

Parity error, 123, 125 

Patching, I68 

Planning, viii, I6I 

Power, kl 

Presumptive address , 93 

Printer, viii 

Print-out, I67 

Program, vii 

Program considerations, 161 

Program testing, x/ I67 , I68 

Pseudo instructions, 55 i 60 

P\anch , viii 

Quick Reference - instructions, 109-111, 173-I77 

Reading punched cards, ix/x , I67 

Read Tape routine, 122, 123 

Reassemble, I68 

Reflective spot, 119 

Registers: 

AC and MQ registers, 17, 18, 35 

SI (sense Indicator) register, I7, 1^7 

XR (Index) registers, 17, 93 

Review, 111-118, 177-19^ 

Right adjusted, 81, 86 

Self Test, 111-118, I77-194 

Sense indicators, 17 » 22, 1^7 

Sense lights , 152 

Sense switches, IU7 

Sorting, l6k 

Source program, x/ I67 , 168 

Spills, 51 

Storage , viii 

Storage location, 15 

Storage unit , 15 

Symbolic coding, 55 

Symbolic coding sheet, 59 

Symbolic language, 63 

Symbols for aritlxmetic operations, 59 
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Tape, vlii , 119 

Tape mark, 119 

Term, 63 

Test data, 167 

Trailer label, 119 

Transfer trapping, l62 

Trapping, 51, l62 

Trap trace program, 162, I63 

Undefined symbol, 55 
Underflow, 51 
Unnormalized number, kl 
Unpacking, l40 



Word, 15 

Write Tape routine, 124, 125 
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